React Router v5 vs v6 路由配置對比

React Router v5 vs v6 路由配置對比

React Router 是 React 中最常用的路由庫,從 v5 到 v6 版本,發生了較大變化。本文對比 React Router v5React Router v6 的配置方式,幫助開發者順利遷移。

1. 安裝依賴

React Router v5

npm install react-router-dom@5

React Router v6

npm install react-router-dom@latest

2. 基本路由配置

v5 版本 (使用 Switchcomponent)

import { BrowserRouter as Router, Route, Switch } from "react-router-dom";
import Home from "./Home";
import About from "./About";function App() {return (<Router><Switch><Route exact path="/" component={Home} /><Route path="/about" component={About} /></Switch></Router>);
}export default App;

v6 版本 (使用 Routeselement)

import { BrowserRouter as Router, Route, Routes } from "react-router-dom";
import Home from "./Home";
import About from "./About";function App() {return (<Router><Routes><Route path="/" element={<Home />} /><Route path="/about" element={<About />} /></Routes></Router>);
}export default App;

主要區別:

  • Switch 在 v6 中被 Routes 取代。
  • Route 不再使用 component={},而是改為 element={<Component />}
  • exact 默認生效,v6 無需手動添加。

3. 動態路由

v5 版本 (match.params)

import { useParams } from "react-router-dom";function User() {const { id } = useParams();return <h1>User ID: {id}</h1>;
}function App() {return (<Router><Switch><Route path="/user/:id" component={User} /></Switch></Router>);
}

v6 版本 (useParams)

function User() {const { id } = useParams();return <h1>User ID: {id}</h1>;
}function App() {return (<Router><Routes><Route path="/user/:id" element={<User />} /></Routes></Router>);
}

區別: v6 直接在 element 里傳入組件,不使用 component={}


4. 路由重定向

v5 版本 (Redirect)

import { Redirect } from "react-router-dom";function App() {return (<Router><Switch><Route exact path="/"><Redirect to="/home" /></Route><Route path="/home" component={Home} /></Switch></Router>);
}

v6 版本 (Navigate)

import { Navigate } from "react-router-dom";function App() {return (<Router><Routes><Route path="/" element={<Navigate to="/home" />} /><Route path="/home" element={<Home />} /></Routes></Router>);
}

區別: Redirect 在 v6 中被 Navigate 取代,且必須放在 element 里。


5. 路由守衛

v5 版本 (使用 render)

function PrivateRoute({ component: Component, ...rest }) {const isAuthenticated = false; // 示例return (<Route{...rest}render={(props) =>isAuthenticated ? <Component {...props} /> : <Redirect to="/login" />}/>);
}

v6 版本 (使用 Navigate)

function PrivateRoute({ children }) {const isAuthenticated = false; // 示例return isAuthenticated ? children : <Navigate to="/login" />;
}function App() {return (<Router><Routes><Route path="/dashboard" element={<PrivateRoute><Dashboard /></PrivateRoute>} /><Route path="/login" element={<Login />} /></Routes></Router>);
}

區別:

  • v5 使用 render 方法返回不同組件。
  • v6 直接用 Navigate 進行跳轉。

6. 嵌套路由

v5 版本 (match.url)

function Dashboard({ match }) {return (<div><h1>Dashboard</h1><Link to={`${match.url}/settings`}>Settings</Link><Switch><Route path={`${match.path}/settings`} component={Settings} /></Switch></div>);
}

v6 版本 (Outlet)

import { Outlet, Link } from "react-router-dom";function Dashboard() {return (<div><h1>Dashboard</h1><Link to="settings">Settings</Link><Outlet /></div>);
}function App() {return (<Router><Routes><Route path="dashboard" element={<Dashboard />}><Route path="settings" element={<Settings />} /></Route></Routes></Router>);
}

區別:

  • v6 使用 Outlet 代替 match.url 進行嵌套路由。

結論

功能v5v6
路由配置Switch + RouteRoutes + Route
動態路由match.paramsuseParams
重定向RedirectNavigate
路由守衛renderNavigate + 組件包裹
嵌套路由match.urlOutlet

如果你是新項目,建議直接使用 React Router v6,如果是老項目,可以按需升級。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/71812.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/71812.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/71812.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

機器學習,我們主要學習什么?

機器學習的發展歷程 機器學習的發展歷程&#xff0c;大致分為以下幾個階段&#xff1a; 1. 起源與早期探索&#xff08;20世紀40年代-60年代&#xff09; 1949年&#xff1a;Hebb提出了基于神經心理學的學習機制&#xff0c;開啟了機器學習的先河1950年代&#xff1a;機器學習的…

全面理解-深拷貝與淺拷貝

在 C 中&#xff0c;深拷貝&#xff08;Deep Copy&#xff09; 和 淺拷貝&#xff08;Shallow Copy&#xff09; 是兩種完全不同的對象拷貝策略&#xff0c;主要區別在于對指針和動態分配資源的處理方式。正確理解二者的區別是避免內存泄漏、懸空指針和程序崩潰的關鍵。 一、核…

藍橋杯第十六屆嵌入式模擬編程題解析

由硬件框圖可以知道我們要配置LED 和按鍵 LED 先配置LED的八個引腳為GPIO_OutPut&#xff0c;鎖存器PD2也是&#xff0c;然后都設置為起始高電平&#xff0c;生成代碼時還要去解決引腳沖突問題 按鍵 按鍵配置&#xff0c;由原理圖按鍵所對引腳要GPIO_Input 生成代碼&#xf…

在 JavaScript 中,[](空數組)不是假值,它是“真值”(truthy)

文章目錄 語法解釋!this.form.productPhotos 的含義在代碼中的作用具體判斷 實際上下文總結當前代碼的局限 在你的父組件代碼中&#xff0c;出現了 !this.form.productPhotos 這樣的表達式&#xff0c;具體是在 handleSubmit 方法中&#xff1a; private handleSubmit() {if (…

【Springboot3】Springboot3 搭建RocketMQ 最簡單案例

說來也奇怪&#xff0c;RocketMQ 不能很好的兼容Springboot3&#xff0c;剛開始上手Springboot3集成RocketMQ會發現總是不能實例化RocketMQTemplate&#xff0c;老是啟動時報錯。本項目采用Springboot3&#xff0c;JDK21 &#xff0c;Maven 3.9&#xff0c;提供一個非常簡單的示…

抓包工具 wireshark

1.什么是抓包工具 抓包工具是什么&#xff1f;-CSDN博客 2.wireshark的安裝 【抓包工具】win 10 / win 11&#xff1a;WireShark 下載、安裝、使用_windows抓包工具-CSDN博客 3.wireshark的基礎操作 Wireshark零基礎使用教程&#xff08;超詳細&#xff09; - 元宇宙-Meta…

w~視覺~合集13

我自己的原文哦~ https://blog.51cto.com/whaosoft/13384038 #xxx w視覺合集13~17沒了.... #ViTAR 作者提出了一種新穎的架構&#xff1a;任意分辨率的視覺 Transformer &#xff08;ViTAR&#xff09;。ViTAR中的自適應標記合并功能使模型能夠自適應地處理可變分辨率圖像…

漏洞文字版表述一句話版本(漏洞危害以及修復建議),通常用于漏洞通報中簡潔干練【持續更新中】

漏洞文字版表述一句話版本(漏洞危害以及修復建議) SQL注入漏洞 危害描述&#xff1a; SQL注入漏洞允許攻擊者通過構造惡意的SQL語句&#xff0c;繞過應用程序的安全檢查&#xff0c;直接訪問或操作數據庫。這可能導致數據泄露、數據篡改、甚至數據庫被刪除等嚴重后果&#xf…

scp工具

scp 簡介選項將遠程電腦上的文件復制到本地將本地文件復制到遠程電腦 簡介 ??scp???是 secure copy 的縮寫&#xff0c;是基于??ssh??的文件傳輸 命令/工具。 scp 是加密的&#xff0c;rcp 是不加密的&#xff0c;scp 是 rcp 的加強版。 Windows系統中&#xff0c;sc…

微服務即時通信系統---(三)框架學習

目錄 brpc RPC框架 核心概念 工作原理 介紹 安裝 頭文件包含和編譯時指明庫 類與接口介紹 日志輸出類與接口 protobuf類與接口 Closure類 RpcController類 服務端類與接口 ServerOptions類 Server類 ClosureGuard類 HttpHeader類 Controller類 客戶端類與…

初識.git文件泄露

.git 文件泄露 當在一個空目錄執行 git init 時&#xff0c;Git 會創建一個 .git 目錄。 這個目錄包含所有的 Git 存儲和操作的對象。 如果想備份或復制一個版本庫&#xff0c;只需把這個目錄拷貝至另一處就可以了 這是一種常見的安全漏洞&#xff0c;指的是網站的 .git 目錄…

百度百舸 DeepSeek 一體機發布,支持昆侖芯 P800 單機 8 卡滿血版開箱即用

在私有云環境中成功部署 DeepSeek 滿血版并實現性能調優&#xff0c;并不是一件容易的事情。選擇合適的 GPU 配置、安裝相應的環境、成功部署上線業務、加速推理任務加速、支撐多用戶并發 …… 完成業務測試&#xff0c;成功融入生產業務中。 為了幫助企業快速實現 DeepSeek 服…

Mysql 主從集群同步延遲問題怎么解決

主從復制工作原理類比 假設主庫是快遞總倉&#xff0c;從庫是各個分店的倉庫&#xff1a; 總倉每次發貨/退貨都會記錄快遞單&#xff08;binlog&#xff09; 分店派快遞員&#xff08;I/O線程&#xff09;去總倉取快遞單 總倉安排一個打包員&#xff08;binlog dump線程&…

ASP.NET Core 簡單文件上傳

使用異步 JavaScript 和 XML&#xff08;AJAX&#xff09;進行簡單的文件上傳&#xff1b;用 C# 編寫的服務器端代碼。 使用AJAX和ASP.NET Core MVC上傳文件再簡單不過了。這不依賴于jQuery。此代碼允許上傳多個文件&#xff0c;并與 .NET Core 3.1、.NET 6和.NET 8兼容。 如果…

iOS指紋歸因詳解

iOS 指紋歸因&#xff08;Fingerprint Attribution&#xff09;詳解 1. 指紋歸因的概念 指紋歸因&#xff08;Fingerprint Attribution&#xff09;是一種無 ID 歸因&#xff08;ID-less Attribution&#xff09;技術&#xff0c;主要用于廣告跟蹤、用戶識別或流量分析。它基…

GMII(Gigabit Media Independent Interface)詳解

一、GMII的定義與作用 GMII&#xff08;千兆介質無關接口&#xff09;是用于千兆以太網&#xff08;1Gbps&#xff09;的標準化接口&#xff0c;連接 MAC層&#xff08;數據鏈路層&#xff09;與 PHY芯片&#xff08;物理層&#xff09;。其核心目標是支持高速數據傳輸&#x…

C++對象模型之C++額外成本

1.介紹 C與C最大的區別&#xff0c;無疑在于面向對象&#xff0c;面向對象編程給C帶來了強大的特性和靈活性。但同時也帶來了一定的運行時和編譯時的開銷。下面介紹C對象模型的額外成本及其來源。 2.C的額外成本 &#xff08;1&#xff09;虛函數和動態多態的成本 虛函數表&am…

【Excel】【VBA】根據內容調整打印區域

Excel VBA&#xff1a;自動調整打印區域的實用代碼解析 在Excel中&#xff0c;我們經常需要調整打印區域。今天介紹一段VBA代碼&#xff0c;它可以根據C列的內容自動調整打印區域。 Dim ws As Worksheet Dim lastRow As Long Dim r As Long 設置當前工作表 Set ws ActiveSh…

【關于seisimic unix中使用suedit指令無法保存問題】

提示&#xff1a;文章寫完后&#xff0c;目錄可以自動生成&#xff0c;如何生成可參考右邊的幫助文檔 文章目錄 前言一、如何修改頭文件二、出現的問題嘗試解決使用ls顯示文件屬性使用chmod修改文件屬性 總結 前言 提示&#xff1a;這里可以添加本文要記錄的大概內容&#xff…

微前端qiankun打包部署

官網&#xff1a;API 說明 - qiankun 前提&#xff1a;后臺項目&#xff0c;在主應用設置菜單&#xff0c;微應用渲染組件&#xff0c;沒有使用路由跳轉loadMicroApp 1.token需要使用setGlobalState&#xff0c;傳參或者方法用的setGlobalState 2.打包沒有使用Nginx 3.有需…