React-router-dom v6和 v5版本“注册路由”的差异化

2023-12-15 03:01

本文主要是介绍React-router-dom v6和 v5版本“注册路由”的差异化,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

React-router-dom v6和 v5版本“注册路由”的差异化

Matched leaf route at location “/about” does not have an element. This
means it will render an with a null value by default
resulting in an “empty” page.

v6版本中Switch已经被换成了Routes,点击链接路径变化正常但页面不显示,并在浏览器控制台输出以上警告。

解决方法:

原来“注册路由”代码:

现在的代码:

<Route path=“/about” element={}/>

<Route path=“/home” element={}/>

总结React-router-dom从v5升级到v6:
React-router-dom从v5升级到v6有了一些变化:

(2) Switch重命名位Routes

// v5
<Switch><Route exact path="/"><Home /></Route><Route path="/profile"><Profile /></Route>
</Switch>// v6
<Routes><Route path="/" element={<Home />} /><Route path="profile/*" element={<Profile />} />
</Routes>

(2) Route 的新特性变更 ,component/render被element替代

import Profile from ‘./Profile’;

// v5
<Route path=":userId" component={Profile} />
<Routepath=":userId"render={routeProps => (<Profile routeProps={routeProps} animate={true} />)}
/>// v6
<Route path=":userId" element={<Profile />} />
<Route path=":userId" element={<Profile animate={true} />} />

(3) 嵌套路由变得更简单

具体变化有以下:

Route children 已更改为接受子路由。 比Route exact 和 Route strict更简单的匹配规则。 Route
path 路径层次更清晰。

v5 中的嵌套路由必须非常明确定义,且要求在这些组件中包含许多字符串匹配逻辑.

// v5
import {BrowserRouter,Switch,Route,Link,useRouteMatch
} from 'react-router-dom';function App() {return (<BrowserRouter><Switch><Route exact path="/" component={Home} /><Route path="/profile" component={Profile} /></Switch></BrowserRouter>);
}function Profile() {let { path, url } = useRouteMatch();return (<div><nav><Link to={`${url}/me`}>My Profile</Link></nav><Switch><Route path={`${path}/me`}><MyProfile /></Route><Route path={`${path}/:id`}><OthersProfile /></Route></Switch></div>);
}

v6 中,你可以删除字符串匹配逻辑。不需要任何 useRouteMatch()

// v6
import {BrowserRouter,Routes,Route,Link,Outlet
} from 'react-router-dom';function App() {return (<BrowserRouter><Routes><Route path="/" element={<Home />} /><Route path="profile/*" element={<Profile/>} /></Routes></BrowserRouter>);
}function Profile() {return (<div><nav><Link to="me">My Profile</Link></nav><Routes><Route path="me" element={<MyProfile />} /><Route path=":id" element={<OthersProfile />} /></Routes></div>);
}

当然,还有更酸爽的操作,直接在路由里定义的,然后用接下来的一个新API:Outlet

新API:Outlet

function App() {return (<BrowserRouter><Routes><Route path="/" element={<Home />} /><Route path="profile" element={<Profile />}><Route path=":id" element={<MyProfile />} /><Route path="me" element={<OthersProfile />} /></Route></Routes></BrowserRouter>);
}function Profile() {return (<div><nav><Link to="me">My Profile</Link></nav>{/* 将直接根据上面定义的不同路由参数,渲染<MyProfile /> 或 <OthersProfile /> */}<Outlet /></div>)
}

多个 Routes
以前,我们只能在 React App 中使用一个 Routes。但是现在我们可以在 React App 中使用多个路由,这将帮助我们基于不同的路由管理多个应用程序逻辑。

import React from 'react';
import { Routes, Route } from 'react-router-dom';function Dashboard() {return (<div><p>Look, more routes!</p><Routes><Route path="/" element={<DashboardGraphs />} /><Route path="invoices" element={<InvoiceList />} /></Routes></div>);
}function App() {return (<Routes><Route path="/" element={<Home />} /><Route path="dashboard/*" element={<Dashboard />} /></Routes>);
}

(4) 用 useNavigate 代替 useHistory

// v5
import { useHistory } from 'react-router-dom';function MyButton() {let history = useHistory();function handleClick() {history.push('/home');};return <button onClick={handleClick}>Submit</button>;
};
// v6
import { useNavigate } from 'react-router-dom';function MyButton() {let navigate = useNavigate();function handleClick() {navigate('/home');};return <button onClick={handleClick}>Submit</button>;
};

history的用法也将被替换成navigate

// v5
history.push('/home');
history.replace('/home');// v6
navigate('/home');
navigate('/home', {replace: true});

(5) 新钩子 useRoutes 代替 react-router-config

function App() {let element = useRoutes([{ path: '/', element: <Home /> },{ path: 'dashboard', element: <Dashboard /> },{ path: 'invoices',element: <Invoices />,children: [{ path: ':id', element: <Invoice /> },{ path: 'sent', element: <SentInvoices /> }]},// 重定向{ path: 'home', redirectTo: '/' },// 404找不到{ path: '*', element: <NotFound /> }]);return element;
}

(6) 大小减少:从20kb到8kb
React Router v6给我们带来方便的同时,还把包减少了一半以上的体积

如果对你有帮助,可以点点关注点点赞谢谢哈!

这篇关于React-router-dom v6和 v5版本“注册路由”的差异化的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/494871

相关文章

HTML5的input标签的`type`属性值详解和代码示例

《HTML5的input标签的`type`属性值详解和代码示例》HTML5的`input`标签提供了多种`type`属性值,用于创建不同类型的输入控件,满足用户输入的多样化需求,从文本输入、密码输入、... 目录一、引言二、文本类输入类型2.1 text2.2 password2.3 textarea(严格

SpringBoot返回文件让前端下载的几种方式

《SpringBoot返回文件让前端下载的几种方式》文章介绍了开发中文件下载的两种常见解决方案,并详细描述了通过后端进行下载的原理和步骤,包括一次性读取到内存和分块写入响应输出流两种方法,此外,还提供... 目录01 背景02 一次性读取到内存,通过响应输出流输出到前端02 将文件流通过循环写入到响应输出流

SpringBoot+Vue3整合SSE实现实时消息推送功能

《SpringBoot+Vue3整合SSE实现实时消息推送功能》在日常开发中,我们经常需要实现实时消息推送的功能,这篇文章将基于SpringBoot和Vue3来简单实现一个入门级的例子,下面小编就和大... 目录前言先大概介绍下SSE后端实现(SpringBoot)前端实现(vue3)1. 数据类型定义2.

nacos服务无法注册到nacos服务中心问题及解决

《nacos服务无法注册到nacos服务中心问题及解决》本文详细描述了在Linux服务器上使用Tomcat启动Java程序时,服务无法注册到Nacos的排查过程,通过一系列排查步骤,发现问题出在Tom... 目录简介依赖异常情况排查断点调试原因解决NacosRegisterOnWar结果总结简介1、程序在

前端Visual Studio Code安装配置教程之下载、汉化、常用组件及基本操作

《前端VisualStudioCode安装配置教程之下载、汉化、常用组件及基本操作》VisualStudioCode是微软推出的一个强大的代码编辑器,功能强大,操作简单便捷,还有着良好的用户界面,... 目录一、Visual Studio Code下载二、汉化三、常用组件1、Auto Rename Tag2

Python包管理工具uv下载python版本慢问题解决办法

《Python包管理工具uv下载python版本慢问题解决办法》uv是一个非常快的Python包和项目管理器,用Rust编写,使用热缓存安装Trio的依赖项的速度对比,:本文主要介绍Python包... 目录发现问题对于 MACOS / linux 用户 (zsh/bash):对于 Windows 用户:总

vite搭建vue3项目的搭建步骤

《vite搭建vue3项目的搭建步骤》本文主要介绍了vite搭建vue3项目的搭建步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1.确保Nodejs环境2.使用vite-cli工具3.进入项目安装依赖1.确保Nodejs环境

Nginx搭建前端本地预览环境的完整步骤教学

《Nginx搭建前端本地预览环境的完整步骤教学》这篇文章主要为大家详细介绍了Nginx搭建前端本地预览环境的完整步骤教学,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录项目目录结构核心配置文件:nginx.conf脚本化操作:nginx.shnpm 脚本集成总结:对前端的意义很多

Python版本与package版本兼容性检查方法总结

《Python版本与package版本兼容性检查方法总结》:本文主要介绍Python版本与package版本兼容性检查方法的相关资料,文中提供四种检查方法,分别是pip查询、conda管理、PyP... 目录引言为什么会出现兼容性问题方法一:用 pip 官方命令查询可用版本方法二:conda 管理包环境方法

前端缓存策略的自解方案全解析

《前端缓存策略的自解方案全解析》缓存从来都是前端的一个痛点,很多前端搞不清楚缓存到底是何物,:本文主要介绍前端缓存的自解方案,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、为什么“清缓存”成了技术圈的梗二、先给缓存“把个脉”:浏览器到底缓存了谁?三、设计思路:把“发版”做成“自愈”四、代码