React-Router-嵌套路由
  TEZNKK3IfmPf 2023年11月12日 51 0
  • 路由里面又有路由, 我们就称之为嵌套路由

新建 Discover.js:

import React from 'react';
import {NavLink, Switch, Route} from "react-router-dom";

function Hot() {
return (
<div>推荐</div>
)
}

function TopList() {
return (
<div>排行榜</div>
)
}

function PlayList() {
return (
<div>歌单</div>
)
}

class Discover extends React.PureComponent {
render() {
return (
<div>
<NavLink exact to={'/discover'} activeStyle={{color: 'red'}}>推荐</NavLink>
<NavLink exact to={'/discover/toplist'} activeStyle={{color: 'red'}}>排行榜</NavLink>
<NavLink exact to={'/discover/playlist'} activeStyle={{color: 'red'}}>歌单</NavLink>

<Switch>
<Route exact path={'/discover'} component={Hot}/>
<Route exact path={'/discover/toplist'} component={TopList}/>
<Route exact path={'/discover/playlist'} component={PlayList}/>
</Switch>
</div>
)
}
}

export default Discover;

App.js:

import React from 'react';
import Home from './components/Home'
import About from './components/About'
import Other from './components/Other'
import User from './components/User'
import Login from './components/Login'
import Discover from './components/Discover'
import {BrowserRouter, NavLink, Route, Switch} from 'react-router-dom';

class App extends React.PureComponent {
render() {
return (
<div>
<BrowserRouter>
<NavLink to={'/home'} activeStyle={{color: 'red'}}>Home</NavLink>
<NavLink to={'/about'} activeStyle={{color: 'red'}}>About</NavLink>
<NavLink to={'/user'} activeStyle={{color: 'red'}}>User</NavLink>
<NavLink to={'/discover'} activeStyle={{color: 'red'}}>广场</NavLink>

<Switch>
<Route exact path={'/home'} component={Home}/>
<Route exact path={'/about'} component={About}/>
<Route exact path={'/user'} component={User}/>
<Route exact path={'/login'} component={Login}/>
<Route path={'/discover'} component={Discover}/>
<Route component={Other}/>
</Switch>
</BrowserRouter>
</div>
)
}
}

export default App;

注意点

  • 如果要使用嵌套路由, 那么外层的路由不能添加精准匹配​​exact​
  • 如果子路由的组件是在 BrowserRouter or HashRouter 中显示的, 那么就不用再当前组件在用使用 BrowserRouter or HashRouter 来包裹 NavLink/Switch/Route
【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

上一篇: React-Router-Switch 下一篇: React-Router-Redirect
  1. 分享:
最后一次编辑于 2023年11月12日 0

暂无评论

推荐阅读
  TEZNKK3IfmPf   2023年11月15日   31   0   0 reactjavascript
  TEZNKK3IfmPf   2024年03月29日   104   0   0 静态路由
  TEZNKK3IfmPf   2023年11月14日   19   0   0 react
  TEZNKK3IfmPf   2023年11月14日   15   0   0 react函数
  TEZNKK3IfmPf   2023年11月14日   22   0   0 react
  TEZNKK3IfmPf   2023年11月14日   25   0   0 react继承
  TEZNKK3IfmPf   2023年11月14日   17   0   0 react编程开发
  TEZNKK3IfmPf   2023年11月14日   20   0   0 react编程开发
  TEZNKK3IfmPf   2023年11月14日   18   0   0 react编程开发
  TEZNKK3IfmPf   2023年11月14日   19   0   0 react编程开发
  TEZNKK3IfmPf   2023年11月14日   22   0   0 react
  TEZNKK3IfmPf   2023年11月14日   34   0   0 react
  TEZNKK3IfmPf   2024年03月22日   67   0   0 htmlreact
  TEZNKK3IfmPf   2023年11月15日   30   0   0 react
  TEZNKK3IfmPf   2023年11月14日   27   0   0 react
TEZNKK3IfmPf