我很难弄清楚如何使用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>
任何帮助/指示都将受到高度赞赏。
由于
答案 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>
}
});