React 路由的使用以及bug规避:路由跳转、路由传参、嵌套路由

简介: React 路由的使用以及bug规避:路由跳转、路由传参、嵌套路由

React 路由


准备


react路由在使用前需要装包

npm i react-router-dom@5.3.0
• 1

装完包后就可以在对应的页面使用了,下面是路由的几个常用方法

import { HashRouter as Router, Route, Link,NavLink,Switch,Redirect,useHistory } from 'react-router-dom'
• 1

说明:

HashRouter 哈希模式路由 —HashRouter as Router这种写法为取别名 Router

Route 路由组件 执行路由分发

Link 链接上显示的路由更新 类似于a标签

NavLink 路由更新 跟Link效果相同,但是NavLink上会有class类名active ,可以通过类名设置高亮

Switch 用Swich包裹路由组件,不管有多少个路由匹配成功,都只会显示第一个匹配的组件,不设置path属性,将404页对应的路由放在switch内部的最后位置,没有匹配到路由时会显示最后的那个404路由

Redirect 路由重定向

useHistory 路由历史模式


基础路由演示


import React from "react"
import './App.scss'
// 给路由取别名 Router  哈希模式
import { HashRouter as Router, Route, Link,NavLink,Switch,Redirect } from 'react-router-dom'
import Home from './Component/Home'
import GoodsClass from './Component/GoodsClass'
import Cart from './Component/Cart'
import My from './Component/My'
import Page404 from './Component/Page404'
export default function App() {
    return (
        <>
            <div>App
                <br />
                <Router>
                    <Link to='/home'>首页</Link>
                    <br />
                    <Link to='/goodsClass'>分类</Link>
                    <br />
                    <Link to='/cart'>购物车</Link>
                    <br />
                    <NavLink to='/my'>我的</NavLink>
                    <hr />
                    <Switch>
                       <Redirect from="/" exact to={'/home'}></Redirect>
                       <Route path='/home' exact  component={Home}></Route>
                       <Route path='/goodsClass' exact  component={GoodsClass}></Route>
                       <Route path='/cart' exact  component={Cart}></Route>
                       <Route path='/my'  component={My}></Route>
                       {/* 如果未匹配到路由则会显示404路由 配合Switch使用 */}
                       <Route component={Page404}></Route>
                    </Switch>
                </Router>
            </div>
        </>
    )
}

react路由使用的是模糊匹配,如果想要精准匹配的话需要在路由上加 exact 关键字

<Route path='/home' exact  component={Home}></Route>
• 1

路由组件中间不能有空格,否则会报错


<Route path='/home' exact  component={Home}> </Route>     {/* 中间有空格,报错 */}
• 1

react的参数传递


路由跳转的链接上可以携带参数,在组件上用 :id 携带


<Link to='/cart/3'>购物车</Link>
<Route path='/cart/:id' exact  component={Cart}></Route>
• 1
• 2
• 3

路由跳转后接参

有两种接参方式

1. useParams

使用useParams接参前,需要引入


import { useParams } from "react-router-dom"
const params = useParams()
console.log(params);  // 这里打印的就是路由携带的参数
• 1
• 2
• 3
• 4

2. props

直接使用props接参

export default function Cart (props) {
   console.log(props.match.params);   // 这里打印的就是路由携带的参数
}
• 1
• 2
• 3


路由跳转&&编程式导航


路由跳转的4种方式


使用 history 对象

import { useHistory } from "react-router-dom"
const history = useHistory()
• 1
• 2
• 3

1. push和goBack

// 页面回退 会向 history 栈添加一个新的记录,所以,当用户点击浏览器后退按钮时,则回到之前的 URL
history.push('/home')
// 返回上一个页面 栈添加一个新的记录,所以,当用户点击浏览器后退按钮时,则回到之前的 URL
history.goBack()
• 1
• 2
• 3
• 4
• 5

2. go

// 前进或后退到某个页面,参数 n 表示前进或后退页面数量(比如:-1 表示后退到上一页) 不会存储到历史记录中
history.go(-1)
• 1
• 2

3. replace

// 进入/home ,在历史记录中用目标记录来替换当前记录
history.replace('/home')
• 1
• 2

history.replace和push的区别

push:向历史记录中添加一条

replace:在历史记录中用目标记录来替换当前记录

示例

push

详情页  --> login页(push)  ----> 主页 
• 1

此时,从主页后退,会回到login页。

replace

详情页  --> login页(replace)  ----> 主页 
• 1

此时,从主页后退,会回到详情页。


嵌套路由


在对应的子路由嵌套路由即可,跟父级路由的写法一样,下面是路由演示


import React from "react"
import { Route,NavLink,Switch,Redirect } from "react-router-dom"
import MyOrder from './MyOrder'
import MyGoods from './MyGoods'
export default function My () {
    return (
        <div>My
            <br />
            <ul>
                <li>
                  <NavLink to='/my/order'>我的订单</NavLink>
                </li>
                <li>
                <NavLink to='/my/goods'>我的商品</NavLink>
                </li>
            </ul>
            <Switch>
                <Redirect from='/my' exact to={'/my/order'}></Redirect>
                <Route path='/my/order' component={MyOrder}></Route>
                <Route path='/my/goods' component={MyGoods}></Route>
            </Switch>
        </div>
    )
}

嵌套路由重定向的小坑


如果子路由内有嵌套路由,在父级路由组件上不能加 exact 关键字,否则会匹配不上导致重定向失败


{/* 当前路由为父级路由 如果跳转的路由页面内部有嵌套路由,则不能在当前页加exact */}
 <Route path='/my'  component={My}></Route>
目录
相关文章
|
4月前
|
前端开发 JavaScript
React项目路由懒加载lazy、Suspense,使第一次打开项目页面变快
本文介绍了在React项目中实现路由懒加载的方法,使用React提供的`lazy`和`Suspense`来优化项目首次加载的速度。通过将路由组件改为懒加载的方式,可以显著减少初始包的大小,从而加快首次加载速度。文章还展示了如何使用`Suspense`组件包裹`Switch`来实现懒加载过程中的fallback效果,并提供了使用前后的加载时间对比,说明了懒加载对性能的提升作用。
298 2
React项目路由懒加载lazy、Suspense,使第一次打开项目页面变快
|
2月前
|
前端开发 API UED
React 路由守卫 Guarded Routes
【10月更文挑战第26天】本文介绍了 React 中的路由守卫(Guarded Routes),使用 `react-router-dom` 实现权限验证、登录验证和数据预加载等场景。通过创建 `AuthContext` 管理认证状态,实现 `PrivateRoute` 组件进行路由保护,并在 `App.js` 中使用。文章还讨论了常见问题和易错点,提供了处理异步操作的示例,帮助开发者提升应用的安全性和用户体验。
65 1
|
5月前
|
移动开发 资源调度 前端开发
介绍React路由模式
【8月更文挑战第10天】介绍React路由模式
66 12
|
2月前
|
前端开发 安全 网络安全
React——路由Route
React——路由Route
39 2
React——路由Route
|
3月前
|
资源调度 前端开发 测试技术
React Router 路由管理
【10月更文挑战第10天】本文介绍了 React Router,一个在 React 应用中管理路由的强大工具。内容涵盖基本概念、安装与使用方法、常见问题及解决方案,如路由嵌套、动态路由和路由守卫等,并提供代码示例。通过学习本文,开发者可以更高效地使用 React Router,提升应用的导航体验和安全性。
365 19
|
3月前
|
前端开发 网络架构
React 路由
10月更文挑战第11天
43 2
|
3月前
|
前端开发 JavaScript 网络架构
实现动态路由与状态管理的SPA——使用React Router与Redux
【10月更文挑战第1天】实现动态路由与状态管理的SPA——使用React Router与Redux
55 1
|
4月前
|
前端开发 Python
React技术栈-React路由插件之自定义组件标签
关于React技术栈中React路由插件自定义组件标签的教程。
73 4
React技术栈-React路由插件之自定义组件标签
|
4月前
|
前端开发 JavaScript
React配合axios请求拦截校验session,403跳转至登陆页面
React中使用axios进行请求拦截,通过自定义事件监听和响应拦截实现403状态码时的自动登录页面跳转。
125 2
|
4月前
|
移动开发 前端开发 应用服务中间件
React两种路由模式的实现原理
React两种路由模式的实现原理
123 3