我正在将React Router添加到现有项目中。
目前,模型被传递到根组件中,该根组件包含用于子导航的导航组件和主组件。
我发现的React Router的示例只有一个子组件,在不重复两个子组件的情况下更改两个子组件的最佳方法是什么?
如果我正确理解您的要求,则可以在中定义多个组件Route。您可以像这样使用它:
Route
// think of it outside the context of the router, if you had pluggable // portions of your `render`, you might do it like this <App children={{main: <Users/>, sidebar: <UsersSidebar/>}}/> // So with the router it looks like this: const routes = ( <Route component={App}> <Route path="groups" components={{main: Groups, sidebar: GroupsSidebar}}/> <Route path="users" components={{main: Users, sidebar: UsersSidebar}}> <Route path="users/:userId" component={Profile}/> </Route> </Route> ) class App extends React.Component { render () { const { main, sidebar } = this.props; return ( <div> <div className="Main"> {main} </div> <div className="Sidebar"> {sidebar} </div> </div> ) } } class Users extends React.Component { render () { return ( <div> {/* if at "/users/123" `children` will be <Profile> */} {/* UsersSidebar will also get <Profile> as this.props.children, so its a little weird, but you can decide which one wants to continue with the nesting */} {this.props.children} </div> ) } }
另外,请查看 侧边栏 示例应用程序,它应该对您有更多帮助。
编辑: 根据@Luiz的评论:
在最新版本的路由器(v3)中,组件位于props对象的根目录中
所以:
const { main, sidebar } = this.props.children;
变成:
const { main, sidebar } = this.props;
编辑: 在react-router v4中,可以像这样完成(按照新文档中提供的示例):
import React from 'react' import { BrowserRouter as Router, Route, Link } from 'react-router-dom' // Each logical "route" has two components, one for // the sidebar and one for the main area. We want to // render both of them in different places when the // path matches the current URL. const routes = [ { path: '/', exact: true, sidebar: () => <div>home!</div>, main: () => <h2>Home</h2> }, { path: '/bubblegum', sidebar: () => <div>bubblegum!</div>, main: () => <h2>Bubblegum</h2> }, { path: '/shoelaces', sidebar: () => <div>shoelaces!</div>, main: () => <h2>Shoelaces</h2> } ] const SidebarExample = () => ( <Router> <div style={{ display: 'flex' }}> <div style={{ padding: '10px', width: '40%', background: '#f0f0f0' }}> <ul style={{ listStyleType: 'none', padding: 0 }}> <li><Link to="/">Home</Link></li> <li><Link to="/bubblegum">Bubblegum</Link></li> <li><Link to="/shoelaces">Shoelaces</Link></li> </ul> {routes.map((route, index) => ( // You can render a <Route> in as many places // as you want in your app. It will render along // with any other <Route>s that also match the URL. // So, a sidebar or breadcrumbs or anything else // that requires you to render multiple things // in multiple places at the same URL is nothing // more than multiple <Route>s. <Route key={index} path={route.path} exact={route.exact} component={route.sidebar} /> ))} </div> <div style={{ flex: 1, padding: '10px' }}> {routes.map((route, index) => ( // Render more <Route>s with the same paths as // above, but different components this time. <Route key={index} path={route.path} exact={route.exact} component={route.main} /> ))} </div> </div> </Router> ) export default SidebarExample
确保您在此处签出新的React Router v4文档:https : //reacttraining.com/react-router/