IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> React Hook第七篇----React路由(详细篇) -> 正文阅读

[JavaScript知识库]React Hook第七篇----React路由(详细篇)

🚀🚀首发:CSDN碰磕,学无止境


💧💧💧小雨


??You can`t have a better tomorrow if you don-t stop thinking about yesterday.


📅2022/6/18


React中的路由

在React快速入门的文章中其实已经讲过了,但写的不是特别细,这里再发表一篇详细了解
路由6版本中新增的新特性

路由V6特性

<Switch>重命名为<Routes>

component/render被element替代

默认显示路由添加index属性,默认为true

Redirect 组件取消 变为 Navigate

使用useNavigate替代了useHistory

v6移出了WithRouter,添加了一些新的hooks

使用`useRoutes`替代了v5的`react-router-config`API:Outlet

安装引入

这里路由讲解的是v6以上版本的,所以安装时注意版本

npm i react-router-dom
//引入
import {BrowserRouter,Route, Routes} from 'react-router-dom';

一级路由与多级路由

语法:

path是跳转路径,element是展示的组件内容(6版本以上)

<BrowserRouter>
           <Routes>
           	<Route path='/路径1' element={组件标签}></Route>
           	<Route path='/路径2' element={组件标签}></Route>
           </Routes>
</BrowserRouter>

重定向

exact精确匹配

//6版本以下
<Redirect from="/" to="/center" exact />

6版本以上需要引入Navigate实现重定向

//6版本以上
import {BrowserRouter,Route, Routes,Navigate} from 'react-router-dom';
<Route path="/" element={<Navigate to ="/center" />}/>

配置404页面拦截

通过*表示只要上方路径都不对,则进入NotFound组件页面

<Route path='*' element={<NotFound/>} />

嵌套路由

Route套Route

<BrowserRouter>
           <Routes>
               <Route path='/center' element={<Center></Center>}>
               <Route path='child' element={<Child />}></Route>
           	   </Route>
           </Routes>
</BrowserRouter>

导航

  • 声明式导航
  • 编程式导航

声明式导航

使用关键字:NavLink,该关键词能得到点击时的标签,并且默认添加class=“active”

注:这里导航需要放到BrowserRouter中,所以这里我通过插槽实现部署到路由BrowserRouter中…

//主页采用插槽
<MRouter>
          <Tabbar></Tabbar>
</MRouter>


//第二个文件路由
 <BrowserRouter>
         {this.props.children}
           <Routes>
               <Route path='/films' element={<Films></Films>}></Route>
               <Route path='/cinemas' element={<Cinemas></Cinemas>}></Route>
               <Route path='/center' element={<Center></Center>}>
                 <Route path='child' element={<Child />}></Route>
               </Route>
               {/* <Redirect from="/" to="/center" /> 旧版重定向*/}
               <Route path='/' element={<Navigate to ="/center" />}  />//首页
               <Route path='*' element={<NotFound/>} /> /*404页*/
           </Routes>
           </BrowserRouter>
	/**
 * 导航组件
 */
 import React from 'react';
import { Link,NavLink } from 'react-router-dom';
import '../css/Tabbar.css'
 function Tabbar(){
     return (
         <div>
            <ul>
                {/**声明式导航 */}  
                <li><NavLink to='/films'>影片</NavLink></li>
                <li><NavLink to='/cinemas'>电影院</NavLink></li>
                <li><NavLink to='/center'>我的中心</NavLink></li>
            </ul>
         </div>
     ); 
 }
 export default Tabbar

编程式导航

  • 原生js(window.location.href)
  • 老版本(this,props.history.push)
  • v6版本以上(使用useNavigate)
import React from 'react';
import {useNavigate} from 'react-router-dom';
function Films(){
    const navigate = useNavigate()
    return (
        <div>
            Films
            <b onClick={goto404=>{
                // window.location.href="/404";//原生js
                // props.history.push("/404")//老版本写法
                navigate("/404")
            }}>去404页(编程式导航)</b>
        </div>
    );
}

export default Films

路由传参

方式1(路径传参)

navigate(`/home/message/detail/${id}/${title}`)

获取数据:函数组件会接收到props
参数在params中

props.match.params.参数名
//这样就拿到传来的数据了

方式2(state传参)

navigate(`/home/message/detail`,{state:{name:'碰磕',age:111},replace:true})

//组件“//home/message/detail”为已经定义好的路由,state负责传值state:{参数:值}

参数在query中

props.match.query.参数名
//这样就拿到传来的数据了

路由拦截

常用于部分页面需要部分权限访问时进行判断拦截

写法

<Route path='/cinemas' element={<RequireAuth> // 拦截组件
            <Cinemas /> // 被拦截组件
          </RequireAuth>}></Route>

RequireAuth为拦截的函数
Cinemas时需要拦截的组件

function RequireAuth({ children }) {
  const authed = "true"
  return authed === 'true' ? ( // 判断 localstorage 中登录状态是否为 true
    children
  ) : (
    <Navigate to="/center" replace /> // 跳转到登录
  );
}

里边进行逻辑判断,正确则返回传进来的要跳转的组件标签,反之跳转到另一个页面…

这样就学会了路由了~够详细不,不够再写😂😂😂

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-06-25 18:01:20  更:2022-06-25 18:02:41 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 11:10:32-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码