【React】react-router 路由详解

简介: 【React】react-router 路由详解

1.什么是路由

前端路由就是把不同路由对应不同的内容或页面的任务交给前端来做,根据不同的url地址展示不同的内容或页面。

一个针对React而设计的路由解决方案、可以友好的帮你解决React Components 到 URL 之间的同步映射关系。

2.路由安装

npm install react-router-dom@5

react-router-dom 的理解

  1. react 的一个插件库。
  2. 专门用来实现一个SPA应用。
  3. 基于react 的项目基本都会用到此库。

react-router-dom相关API

内置组件

<BrowserRouter> /<HashRouter>/ <Route> /<Link>/ <Switch>

其他

history 对象 / match 对象 / withRouter函数

3.路由使用

基本使用

路由方法导入

import { Link,Route } from 'react-router-dom'

路由链接

<link to="/home">About</link>

to属性的值表示要跳转的路由,react中link就相当于 a 标签。

注册路由

import Home from '...'
...
<Route path="/home" component={Home}></Route>

path属性的值表示 Route 匹配的路由,component属性的值表示与这个路由路径相匹配的组件。

注意: <Link/>标签和 <Route/>标签必须要在 Router的内部写入才生效,且 <Link/> 标签和 <Route/>标签在同一个 Router中。

这里的 Router有两种形式:BrowserRouterHashRouter

BrowserRouter与HashRouter的区别

  1. 底层原理不一样:
  1. BrowserRouter使用的是H5的history API,不兼容IE9及以下的版本。
  2. HashRouter使用的是URL哈希值。
  1. path表现形式不一样:
  1. BrowserRouter的路径中没有#,例如:location:3000/demo/test
  2. HashRouter的路径包含#,例如:location:3000/#/demo/test
  1. 刷新后对路由state参数的影响:

(1). BrowserRouter没有任何影响,因为state保留在history对象中。

(2). HashRouter刷新后会导致state参数的丢失!

4.备注:HashRouter可以用于解决一些路径错误相关的问题。

NavLink的使用

在项目开发中,我们经常遇到 路由切换显示高亮的效果。

如图:

Navlink的作用与上文提到的 <Link>一样,只是又另外提供了一个 activeClassName属性,activeClassName属性指定选中路由的a链接的样式。

import {NavLink} from 'react-router-dom'
<NavLink activeClassName="atguigu">About</NavLink>

Switch的使用

Switch可以提高路由匹配效率(单一匹配)。

路由默认情况下使用的是模糊匹配。比如:

<Route path="/home" component={Home}/>
<Route path="/home/detail" component={Detail}/>

在路由的模糊匹配下,当进入‘xxx/home/detail’这个网址时,路由能同时匹配到 ‘/home’ 和 '/home/detail’两个路由,那么页面上将会同时出现 Home 和 Detail 两个组件的内容。

为了避免这种情况的发生,我们需要把路由写入 标签内,作用是:当路由匹配到一个 path 后,就不再继续向下匹配了。

<Switch>
  <Route path="/home" component={Home}/>
  <Route path="/home/detail" component={Detail}/>
</Switch>

另一种解决办法就是修改 <Route/> 的匹配模式为严格模式

严格模式

<Route path="/home" component={Home} exact>

exact精确匹配{Redirect}即使使用了exact,外面还要嵌套<Switch/>来用。

注意:

严格匹配不要随便开启,有需要再开,因为有时候开启会导致无法继续匹配二级路由。

redirect重定向

<Route exact path="/" component={Home}></Route>
  <Route path="/about" component={About}></Route>
    <Route path="/news" component={News}></Route>
    <Redirect from="/" to="/about"></Redirect>
  <Redirect from="/*" to="/login"></Redirect>

1.当用户访问某个页面的时候, 该页面并不存在,此时需要Redirect 重定向, 重新跳到一个我们一个自定义的组件里边。

<Redirect from="/*" to="/login"></Redirect>

2.如果进入到首页面,首页需要默认展示一些东西(数据)。此时path=’/’,如果什么路由组件都没有匹配到, 就需要Redirect重定向,跳转到要展示的页面。

<Redirect from="/" to="/about"></Redirect>

<Redirect/> 写在<Switch/>标签内,所有的<Route/>路由之后。

向路由组件传参的三种方式

路由组件与一般组件的区别

  1. 写法不同

一般组件:<Demo/>

路由组件:<Route path="/demo" component={Demo}/>

  1. 通常存放位置不同

一般组件: components文件夹下

路由组件: pages文件夹下

3.接收到的props不同:

一般组件:组件标签内写了什么属性,就能收到什么。

路由组件:接收到三个固定的属性

history:{
    ...
    go: f go(n),
    goBack: f goBack(),
    goForward: f goForward(),
    push: f push(path,state),
    replace: f replace(path,state)
},
location:{
    ...
    pathname:'/xxx',
    search:"",   
    state:undefined
},
match:{
    ...
  params: {}
  path: '/xxx'
  url: '/xxx'
}     

1.params参数

路由链接携带参数:

<link to="/demo/test/Tom/18">详情</link>

注册路由:

<Route path="/demo/test/:name/:age" component={Test}/>

路由组件接收参数:

const {name,age} = this.props.match.params

2.search参数

路由链接携带参数:

<link to="/demo/test?name=Tom&age=18">详情</link>

注册路由:

<Route path="/demo/test" component={Test}/>

路由组件接收参数:

const {search} = this.props.location

此时 search=’?name=Tom&age=18’

需要借助querystring, 将获取到的search解析为一个对象。

import qs from 'querystring'
qs.parse(search.slice(1))

3.state参数

路由链接携带参数:

<link to={{path:"demo/test",state:{name:'Tom',age18}}}>详情</link>

注册路由:

<Route path="/demo/test" component={Test}/>

路由组件接收参数:

const {name,age} = this.props.location.state

前两种传参方式,传递的参数在path上有所体现,参数随path的改变而改变。

state传参方式在 BrowserRouter下,只要不清除浏览器缓存,即使页面刷新也可以保留住参数,因为location对象是histoty对象的一部分,也就是说state保存在history中。当使用HashRouter时,页面刷新会造成参数丢失,因为 hashRouter中没有history对象来保存state。

声明式导航与编程式导航

push()

params传参

<Link to={/home/message/detail/${msgobj.id}/${msgobj.title}}>
{msgobj.title}</Link>
this.props.history.push(`/home/message/detail/${id}/${title}`)

search参数

<Link to={/home/message/detail/?id=${msgobj.id}&title=${msgobj.title}}>
{msgobj.title}</Link>
this.props.history.push(`/home/message/detail?id=${id}&title=${title}`)

state传参

<Link to={{`
          `pathname:'/home/message/detail',`
          `state:{id:msgobj.id,title:msgobj.title}`
         `}}>{msgobj.title}</Link>
this.props.history.push(`/home/message/detail`,{id,title})

replace()同理

this.props.history.goBack()后退

this.props.history.goForward()前进

this.props.history.go(num)前进(后退)num步

WithRouter

可以加工一般组件,让一般组件具备路由组件所特有的API。

import { withRouter } from 'react-router-dom'
...
class Header extends Component {
  ...
}
export default withRouter(Header)

WithRouter 返回值是一个新组件。

4.反向代理

安装包

npm install http-proxy-middleware --save

配置文件

在src根目录新建 setupProxy 文件,写入如下代码:

const {createProxyMiddleware} = require('http-proxy-middleware')
module.exports = function(app){
    app.use(
        "/ajax", //我们可以在这里设置个口令  
        createProxyMiddleware({
            target:'http://i.maoyan.com', //target是api服务器地址 
            changeOrigin: true, //这个是是否替换这里一定要写true  
            // 去掉我们添加的前缀,保证我们传递给后端的接口是正常的
            pathRewrite: { "^/api": '' } //这是个正则匹配
        })
    );
};

5.cssModule

场景:由于各个组件内引用的css文件,最终会合并在 /public/index.html的

修改css文件名并引入css文件

import style from'./css/Film.module.css'

只要引入的css文件不同,即使在不同的组件中使用相同的类名如 style.bigbox,最终形成的类名仍不相同。

<div className={style.bigbox}></div>


相关文章
|
1月前
|
前端开发 JavaScript
React和Vue实现路由懒加载
React和Vue实现路由懒加载
49 2
|
1月前
|
存储 资源调度 前端开发
React原理 即 React路由基础
React原理 即 React路由基础
61 1
|
1月前
|
前端开发
如何使用react-router v6快速搭建路由?
如何使用react-router v6快速搭建路由?
78 0
|
1月前
|
资源调度 前端开发 JavaScript
React 的antd-mobile 组件库,嵌套路由
React 的antd-mobile 组件库,嵌套路由
70 0
|
1天前
|
前端开发 JavaScript API
React小记(四)_路由的基本使用
React小记(四)_路由的基本使用
6 1
|
1月前
|
资源调度 前端开发 JavaScript
React Router:React应用的路由管理
【4月更文挑战第25天】React Router是React的官方路由库,用于管理SPA的路由。它基于组件,将URL映射到React组件,核心概念包括路由、链接和导航。设置路由时,在根组件中使用BrowserRouter或HashRouter,包裹Routes组件,定义Route规则。Link组件用于创建内部链接,实现导航。高级特性包括嵌套路由、参数化路由和编程式导航,如子路由、动态参数和JavaScript控制的导航。掌握React Router能帮助开发者更高效地构建复杂的React应用。
|
1月前
|
前端开发 中间件 数据安全/隐私保护
React路由进阶方法
React路由进阶方法
36 1
|
1月前
|
JavaScript 前端开发 网络安全
vue与react路由拦截
vue与react路由拦截
47 4
|
1月前
|
设计模式 前端开发 数据可视化
【第4期】一文了解React UI 组件库
【第4期】一文了解React UI 组件库
203 0
|
1月前
|
存储 前端开发 JavaScript
【第34期】一文学会React组件传值
【第34期】一文学会React组件传值
42 0