React Router - 在嵌套组件中安装组件

时间:2015-11-04 16:52:37

标签: javascript reactjs react-router

我很难弄清楚如何使用react router v1.0在嵌套组件中安装组件。我有一个加载Layout组件的App组件。然后,Layout组件加载两个组件,Menu和Content。我想根据路由在Content组件中加载不同的组件。

以下是我的示例代码。

var App = React.createClass({
    render : function(){
         return <div><Layout/></div>
     }
});

var Layout = React.createClass({
    render : function(){
        return(
            <div>
                <Menu/>
                <Content/>
            </div>
        )
    }
});

var Content = React.createClass({
    render : function(){
        return <div>This is where i want to mount my components</div>
    }
});

var List = React.createClass({
    render : function(){
        return <div>some list goes here</div>
    }
});

var Graph = React.createClass({
    render : function(){
        return <div>some graph goes here</div>
    }
});

<Router>
    <Route path='/' component={App}>
        <Route path='/list' component={List}/>
        <Route path='/graph' component={Graph}/>
    </Route>
</Router>

任何帮助/指示都将受到高度赞赏。

由于

1 个答案:

答案 0 :(得分:1)

它与基本的React组件完全相同。当您嵌套它们时,它们可以在this.props.children上使用。所以你最终会得到这样的东西:

var App = React.createClass({
    render : function(){
         return <div><Layout>{this.props.children}</Layout></div>
     }
});

var Layout = React.createClass({
    render : function(){
        return(
            <div>
                <Menu/>
                <Content>{this.props.children}</Content>
            </div>
        )
    }
});

var Content = React.createClass({
    render : function(){
        return <div>{this.props.children}</div>
    }
});