react路由5和6新增及区别

React Router 6 相比 React Router 5 进行了一些重要的升级和改动,主要包括 API 的简化、性能优化和新的特性。以下是主要的区别和新增功能:


1. 路由声明方式变化

React Router 5:

javascript 复制代码
import { BrowserRouter as Router, Route, Switch } from "react-router-dom";

<Router>
  <Switch>
    <Route path="/home" component={Home} />
    <Route path="/about" component={About} />
  </Switch>
</Router>;

React Router 6:

javascript 复制代码
import { BrowserRouter as Router, Routes, Route } from "react-router-dom";

<Router>
  <Routes>
    <Route path="/home" element={<Home />} />
    <Route path="/about" element={<About />} />
  </Routes>
</Router>;

区别:

  • SwitchRoutes 取代,Route 需要用 element 传递组件,而不是 component

2. 默认启用嵌套路由

React Router 5:

xml 复制代码
<Router>
  <Route path="/dashboard" component={Dashboard} />
  <Route path="/dashboard/profile" component={Profile} />
</Router>;

React Router 6(嵌套路由):

xml 复制代码
<Routes>
  <Route path="/dashboard" element={<Dashboard />}>
    <Route path="profile" element={<Profile />} />
  </Route>
</Routes>;

区别:

  • 6 版本支持嵌套路由 ,不需要手动拼接路径(/dashboard/profile),而是直接写 profile,这样 Profile 组件会在 Dashboard 组件中渲染 Outlet

3. useNavigate 取代 useHistory

React Router 5:

ini 复制代码
import { useHistory } from "react-router-dom";

const history = useHistory();
history.push("/home");

React Router 6:

ini 复制代码
import { useNavigate } from "react-router-dom";

const navigate = useNavigate();
navigate("/home");

区别:

  • useHistoryuseNavigate 取代,push 变成了 navigate

4. 动态参数 match 变化

React Router 5:

ini 复制代码
<Route path="/user/:id" component={User} />
const { id } = match.params;

React Router 6:

ini 复制代码
<Route path="/user/:id" element={<User />} />
const { id } = useParams();

区别:

  • match.paramsuseParams() 取代,直接在组件内获取动态参数。

5. useRoutes 方式配置路由

React Router 6 新增 useRoutes(),允许用数组方式定义路由:

javascript 复制代码
import { useRoutes } from "react-router-dom";

const routes = [
  { path: "/home", element: <Home /> },
  { path: "/about", element: <About /> },
];

const App = () => {
  return useRoutes(routes);
};

优点:

  • 让路由更符合组件化思想,避免 JSX 层级嵌套过深。

React Router 5:

ini 复制代码
import { Redirect } from "react-router-dom";

<Route path="/" exact>
  <Redirect to="/home" />
</Route>;

React Router 6:

javascript 复制代码
import { Navigate } from "react-router-dom";

<Route path="/" element={<Navigate to="/home" />} />;

区别:

  • RedirectNavigate 取代,必须用 element 传递。

7. exact 默认行为

React Router 6 默认匹配完整路径,不需要 exact

React Router 5:

ini 复制代码
<Route path="/home" exact component={Home} />

React Router 6:

ini 复制代码
<Route path="/home" element={<Home />} />

总结:

特性 React Router 5 React Router 6
路由声明 <Switch> <Routes>
组件传递 component={} element={<Component />}
嵌套路由 需要完整路径 直接嵌套 <Route>
页面跳转 useHistory().push() useNavigate()
获取参数 match.params useParams()
重定向 <Redirect> <Navigate>
exact 关键词 需要 exact 默认精确匹配
路由数组 不支持 useRoutes()

如果你的项目是 React Router 5,升级到 6 可能需要修改这些 API,但整体结构更简洁,代码可读性更好。

相关推荐
练习两年半的工程师2 小时前
使用React和google gemini api 打造一个google gemini应用
javascript·人工智能·react.js
姑苏洛言4 小时前
30天搭建消防安全培训小程序
前端
左钦杨5 小时前
Nuxt2 vue 给特定的页面 body 设置 background 不影响其他页面
前端·javascript·vue.js
yechaoa5 小时前
【揭秘大厂】技术专项落地全流程
android·前端·后端
MurphyChen5 小时前
🤯 一行代码,优雅的终结 React Context 嵌套地狱!
前端·react.js
逛逛GitHub5 小时前
推荐 10 个受欢迎的 OCR 开源项目
前端·后端·github
_xaboy6 小时前
开源 FormCreate 表单设计器配置组件的多语言
前端·vue.js·低代码·开源·可视化表单设计器
uglyduckling04126 小时前
小程序构建NPM失败
前端·小程序·npm
草原上唱山歌6 小时前
C/C++都有哪些开源的Web框架?
前端·c++·开源
烛阴6 小时前
JavaScript 调度:setTimeout 和 setInterval
前端·javascript