zoukankan      html  css  js  c++  java
  • [React] React Router: Nested Routes

    Since react-router routes are components, creating nested routes is as simple as making one route a child of another in JSX. 

    Make the nested component:

    class App extends React.Component {
        render(){
            return(
                <Router history={hashHistory}>
                    <Route path="/" component={Home}>
                        <Route path="about" component={About}>
                            <Route path="contact" component={Contact}></Route>
                        </Route>
                    </Route>
                </Router>
            );
        }
    }

    Change the path:

    const Links = () =>
        <nav >
            <Link activeStyle={{color: 'green'}} to="/">Home</Link>
            <Link activeStyle={{color: 'green'}} to="/about">About</Link>
            <Link activeClassName="active" to="/about/contact">Contact</Link>
        </nav>;

    Pass the props.children to the nested component: 

    const Home = (props) => <div><h1>Home</h1><Links></Links>{props.children}</div>;
    const About = (props) => <div><h1>About</h1>{props.children}</div>;
    const Contact = () => <div><h1>Contact</h1></div>;

    ----------------

    import React from 'react';
    import {hashHistory, Route, Router, Link} from 'react-router';
    
    // About is the child of home, to display the about, we need to access
    // props.children
    const Home = (props) => <div><h1>Home</h1><Links></Links>{props.children}</div>;
    const About = (props) => <div><h1>About</h1>{props.children}</div>;
    const Contact = () => <div><h1>Contact</h1></div>;
    
    
    const Links = () =>
        <nav >
            <Link activeStyle={{color: 'green'}} to="/">Home</Link>
            <Link activeStyle={{color: 'green'}} to="/about">About</Link>
            <Link activeClassName="active" to="/about/contact">Contact</Link>
        </nav>;
    
    class App extends React.Component {
        render(){
            return(
                <Router history={hashHistory}>
                    <Route path="/" component={Home}>
                        <Route path="about" component={About}>
                            <Route path="contact" component={Contact}></Route>
                        </Route>
                    </Route>
                </Router>
            );
        }
    }
    
    export default App;
  • 相关阅读:
    求解一元二次方程
    常用电脑软件
    c语言的布尔量
    unsigned int数据类型最大数
    int数据类型的最大数
    习题6-8 统计一行文本的单词个数
    习题6-6 使用函数输出一个整数的逆序数
    习题6-5 使用函数验证哥德巴赫猜想
    习题6-4 使用函数输出指定范围内的Fibonacci数
    C#委托、泛型委托
  • 原文地址:https://www.cnblogs.com/Answer1215/p/5331180.html
Copyright © 2011-2022 走看看