reactjs – React路由器导航栏示例

前端之家收集整理的这篇文章主要介绍了reactjs – React路由器导航栏示例前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我是React JS的初学者,并希望为我的仪表板开发基于路由器的导航。模型如下:

我创建的app.js代码尝试路由如下:

  1. import React from 'react'
  2. import { render } from 'react-dom'
  3. import { Router,Route,Link } from 'react-router'
  4. import Login from './components/Login.js';
  5.  
  6. const App = React.createClass({
  7. render() {
  8. return (
  9. <div>
  10. <h1>App</h1>
  11. <ul>
  12. <li><Link to="/login">Login</Link></li>
  13. <li><Link to="/inBox">InBox</Link></li>
  14. </ul>
  15. {this.props.children}
  16. </div>
  17. )
  18. }
  19. })
  20.  
  21.  
  22. render((
  23. <li>
  24. <Router>
  25. <Route path="/" component={App}>
  26. <Route path="login" component={Login} />
  27. </Route>
  28. </Router>
  29. </li>
  30. ),document.getElementById('placeholder'))

如何创建导览,如模型所示?

是的,丹尼尔是正确的,但是要扩大他的答案,您的主要应用程序组件需要在其中有一个导航栏组件。这样,当您呈现主应用程序(“/”路径下的任何页面)时,它也将显示导航栏。我猜你不希望你的登录页面显示导航栏,所以不应该是一个嵌套的组件,而应该是自己的。所以你的路线最终会看起来像这样:
  1. <Router>
  2. <Route path="/" component={App}>
  3. <Route path="page1" component={Page1} />
  4. <Route path="page2" component={Page2} />
  5. </Route>
  6. <Route path="/login" component={Login} />
  7. </Router>

而其他组件看起来像这样:

  1. var NavBar = React.createClass({
  2. render() {
  3. return (
  4. <div>
  5. <ul>
  6. <a onClick={() => history.push('page1') }>Page 1</a>
  7. <a onClick={() => history.push('page2') }>Page 2</a>
  8. </ul>
  9. </div>
  10. )
  11. }
  12. });
  13.  
  14. var App = React.createClass({
  15. render() {
  16. return (
  17. <div>
  18. <NavBar />
  19. <div>Other Content</div>
  20. {this.props.children}
  21. </div>
  22. )
  23. }
  24. });

猜你在找的React相关文章