视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
模块化react-router配置方法详解
2020-11-27 21:55:47 责编:小采
文档

react-router模块化配置

因为公司的需要最近踏进了react坑,一直在挖坑填坑,在路由这一块折腾得不行。

直接进入主题,配置react-router模块化

1.先下载react-router-dom

npm install react-router-dom --save

2.在相应的文件引入react-router-dom相应的模块

import { BrowserRouter as Router, Route, Link } from "react-router-dom";

3.在src子创建一个module目录,接着在module目录在创建一个router.js文件,用来配置路由。

//router.js
import Index from '../components/Index'
import New from '../components/New'
 import NewList from '../components/NewList'
 import NewContent from '../components/NewContent'
 
const routes = [
 
 {
 path:"/",
 component:Index,
 exact:true
 },
 {
 path:"/new",
 component:New,
 routes:[
 {
 path:"/new/",
 component:NewContent
 },
 {
 path:"/new/newList",
 component:NewList
 }
 ]
 },
 
]

export default routes

4.在app.js根目录添加相应的跳转路径。

//app.js

import React from 'react';
import './App.css';
import { BrowserRouter as Router, Route, Link } from "react-router-dom";
import router from "./modules/routers"

function App() {
 return (
 <Router>
 <nav className="nav">
 <ul>
 <li>
 <Link to="/">首页</Link>
 </li>
 <li>
 <Link to="/new">新闻</Link>
 </li>
 </ul>
 </nav>
 {
 router.map((router,index)=>{
 
 if(router.exact){
 
 return <Route exact key={index} path={router.path}
 render = {
 props =>(
 <router.component {...props} routes = {router.routes}/>
 )
 }
 />
 
 }else{
 
 return <Route key={index} path={router.path}
 render = {
 props =>(
 <router.component {...props} routes = {router.routes} />
 )
 }
 />
 
 }
 
 })
 }
 </Router>
 );
}

export default App;

注意点:嵌套路由千万不要在<Route/>身上加上component={xxx.xxx},否则在子路由页码就接受不到父路由传递给子路由的数据,重要的事情说三篇

注意点:嵌套路由千万不要在<Route/>身上加上component={xxx.xxx},否则在子路由页码就接受不到父路由传递给子路由的数据,重要的事情说三篇

注意点:嵌套路由千万不要在<Route/>身上加上component={xxx.xxx},否则在子路由页码就接受不到父路由传递给子路由的数据,重要的事情说三篇

解析一下,<Route/>里面的render,这是官方给出的一种固定写法,为了解决父路由传递数据给子路由接受不到的问题。render是一个对象,里面是一个箭头函数,箭头函数放回<router.component {...props} routes = {router.routes} />一个标签,router.component的router对于的是你map传进来的那个形参,传啥写啥;component 是配置文件对应的component ,routes 是传给子路由的数据、(子路由通过this.props.routes 接收)

5.在有子路由的页码配置跳转

import React ,{Component} from 'react';

import { BrowserRouter as Router, Route, Link } from "react-router-dom";

class New extends Component{
 
 render(){
 
 return(
 
 <div className="box">
 <div className="left">
 <ul>
 <li>
 <Link to="/new">New</Link>
 </li>
 <li>
 <Link to="/new/newList">NewList</Link>
 </li>
 </ul>
 </div>
 <div className="right">
 {
 this.props.routes.map((item,index)=>{
 
 return <Route key={index} exact path={item.path} component={item.component}></Route>
 
 })
 }
 </div>
 </div>
 
 )
 
 }
 
}

export default New

最后的结果为:


下载本文
显示全文
专题