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;
  • 相关阅读:
    mysql 压缩备份 压缩还原 命令
    $' ': command not found
    CentOS7查看和关闭防火墙
    Linux系统运维故障排查
    使用netstat、lsof查看端口占用情况
    一道关于二叉树遍历的题目
    curl常用传参方式
    vm centos7中用NAT模式配置上网
    laravel使用过程中一些总结
    MySQL Replication
  • 原文地址:https://www.cnblogs.com/Answer1215/p/5331180.html
Copyright © 2011-2022 走看看