React 中獲取當前路由信息

在 React 中獲取當前路由信息,根據使用的路由庫不同(如 React Router v5/v6 或 Next.js),方法也有所區別。以下是常見場景的解決方案:


1. 使用 React Router v6

獲取當前路徑(pathname)、查詢參數(search)等
import { useLocation, useParams, useSearchParams } from 'react-router-dom';function MyComponent() {// 獲取路徑信息(如 /users/123?name=foo)const location = useLocation();console.log(location.pathname); // "/users/123"console.log(location.search);   // "?name=foo"// 獲取動態路由參數(如 /users/:id)const params = useParams();console.log(params.id); // "123"// 獲取查詢參數(URLSearchParams 對象)const [searchParams] = useSearchParams();console.log(searchParams.get('name')); // "foo"return <div>Current Path: {location.pathname}</div>;
}
獲取路由匹配信息
import { useMatch } from 'react-router-dom';// 檢查當前路由是否匹配某個路徑
const match = useMatch('/users/:id');
if (match) {console.log(match.params.id); // 動態參數
}

2. 使用 React Router v5

獲取路由信息
import { useLocation, useParams, useRouteMatch } from 'react-router-dom';function MyComponent() {const location = useLocation();const params = useParams();const match = useRouteMatch();console.log(location.pathname); // 當前路徑console.log(params);            // 動態參數console.log(match.url);         // 匹配的URLreturn <div>Current Route: {location.pathname}</div>;
}
類組件中獲取路由
import { withRouter } from 'react-router-dom';class MyComponent extends React.Component {render() {const { location, match, params } = this.props;return <div>Path: {location.pathname}</div>;}
}export default withRouter(MyComponent);

3. 在 Next.js 中獲取路由

Pages Router(傳統方式)
import { useRouter } from 'next/router';function MyComponent() {const router = useRouter();// 獲取完整路由信息console.log(router.pathname); // "/posts/[id]"console.log(router.query);    // { id: "123" }(動態參數 + 查詢參數)console.log(router.asPath);   // "/posts/123?name=foo"(瀏覽器顯示的實際路徑)return <div>Current Page: {router.pathname}</div>;
}
App Router(Next.js 13.4+)
// 在 Server Component 中
import { usePathname, useSearchParams } from 'next/navigation';export default function Page() {const pathname = usePathname();       // "/dashboard"const searchParams = useSearchParams(); // URLSearchParams 對象return <div>Path: {pathname}</div>;
}

4. 獲取當前路由的額外場景

獲取路由的 basename
// React Router v6
import { useMatches } from 'react-router-dom';
const matches = useMatches();
console.log(matches[0].pathname); // 包含 basename 的完整路徑// Next.js (需手動處理)
const basePath = process.env.NEXT_PUBLIC_BASE_PATH || '';
監聽路由變化
// React Router
useEffect(() => {const unlisten = history.listen((update) => {console.log('Route changed to:', update.location.pathname);});return unlisten; // 清理監聽
}, []);// Next.js
useEffect(() => {router.events.on('routeChangeComplete', (url) => {console.log('Route changed to:', url);});
}, [router]);

5. 常見問題解決

問題:路由信息未更新
  • 原因:組件未被路由上下文包裹。
  • 解決:確保組件在 <BrowserRouter><Router> 內部:
    // 根組件中
    import { BrowserRouter } from 'react-router-dom';
    ReactDOM.render(<BrowserRouter><App /></BrowserRouter>,document.getElementById('root')
    );
    
問題:Next.js 中 router.query 初始為空
  • 原因:靜態優化導致首次渲染時無參數。
  • 解決:添加加載狀態判斷:
    if (!router.isReady) return <div>Loading...</div>;
    

總結:按需選擇方法

場景推薦 API示例
React Router v6useLocation, useParamsconst { pathname } = useLocation()
React Router v5withRouter, useRouteMatchexport default withRouter(MyComponent)
Next.js Pagesnext/routerconst router = useRouter()
Next.js App Routernext/navigationconst pathname = usePathname()
獲取查詢參數useSearchParams (React Router)const [params] = useSearchParams()
監聽路由變化history.listen 或 Next.js 事件router.events.on('routeChangeComplete', ...)

根據你的路由庫選擇對應方法即可準確獲取當前路由信息!

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

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

相關文章

Sklearn 機器學習 隨機森林 網格搜索獲取最優參數

??親愛的技術愛好者們,熱烈歡迎來到 Kant2048 的博客!我是 Thomas Kant,很開心能在CSDN上與你們相遇~?? 本博客的精華專欄: 【自動化測試】 【測試經驗】 【人工智能】 【Python】 Sklearn 機器學習:隨機森林 + 網格搜索獲取最優參數實戰指南 在構建機器學習模型時,…

力扣-101.對稱二叉樹

題目鏈接 101.對稱二叉樹 class Solution {public boolean check(TreeNode l, TreeNode r) {if (l null && r null)return true;if ((l null && r ! null) || (r null && l ! null))return false;if (l.val ! r.val)return false;return check(l…

從句--02-1--done,doing ,prep 做定語

提示&#xff1a;文章寫完后&#xff0c;目錄可以自動生成&#xff0c;如何生成可參考右邊的幫助文檔 文章目錄定語1.done&#xff08;過去分詞&#xff09;做定語一、過去分詞作定語的位置二、過去分詞作定語的語義特點三、過去分詞作定語與現在分詞作定語的區別四、過去分詞作…

JVM全面解析

摘要&#xff1a;JVM是Java程序運行的核心環境&#xff0c;負責解釋執行字節碼并管理內存。其核心功能包括類加載與驗證、字節碼執行優化、內存管理與垃圾回收&#xff08;GC&#xff09;、跨平臺支持及安全性保障。JVM架構包含程序計數器、虛擬機棧、本地方法棧、堆和方法區等…

SDC命令詳解:使用write_script命令進行輸出

相關閱讀 SDC輸出命令https://blog.csdn.net/weixin_45791458/category_12993272.html?spm1001.2014.3001.5482 write_script命令用于將設計中的屬性設置命令輸出為腳本文件&#xff08;其實它并不是一個SDC命令&#xff0c;歸為此類只是為了方便管理&#xff09;&#xff0c…

?CASE WHEN THEN ELSE END?

?CASE WHEN THEN ELSE END? 是SQL中實現條件邏輯的核心表達式&#xff0c;支持單字段匹配和多條件判斷&#xff0c;適用于數據處理、分類統計等場景。?基本語法形式?SQL中CASE表達式有兩種標準形式&#xff1a;1? 簡單CASE表達式?&#xff08;字段直接匹配&#xff09;C…

飛單誘因:管理漏洞與人性交織

飛單看似是 “員工個人行為”&#xff0c;實則是餐廳管理、激勵機制、外部環境等多重因素共同作用的結果。要根治飛單&#xff0c;需先理清背后的 “動力源”—— 員工為何選擇冒險&#xff1f;一、“收入失衡”&#xff1a;薪資與付出不匹配的 “補償心理”基層員工&#xff0…

工作筆記-----FreeRTOS中的lwIP網絡任務為什么會讓出CPU

工作筆記-----FreeRTOS中的lwIP網絡任務為什么會讓出CPU Author: 明月清了個風Date&#xff1a; 2025.7.30Ps:最近接觸了在FreeRTOS中使用lwIP實現的網絡任務&#xff0c;但是在看項目代碼的過程中出現了一些疑問——網絡任務的優先級為所有任務中最高的&#xff0c;并且任務框…

在 CentOS 系統上安裝 Docker

在 CentOS 系統上安裝 Docker&#xff0c;可按以下步驟操作&#xff1a;一、卸載舊版本&#xff08;如存在&#xff09;bashsudo yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-latest-logrotate \docker-logrotate \docker-…

【CVPR2025】FlowRAM:用區域感知與流匹配加速高精度機器人操作策略學習

文章目錄FlowRAM&#xff1a;用區域感知與流匹配加速高精度機器人操作策略學習一、問題出在哪里&#xff1f;方法部分&#xff1a;從結構到機制&#xff0c;詳解 FlowRAM 的內部設計邏輯1. 動態半徑調度器&#xff1a;自適應注意力機制在 3D 感知中的實現2. 多模態編碼器與序列…

圖片查重從設計到實現(5)Milvus可視化工具

要通過網頁&#xff08;Web&#xff09;訪問和管理 Milvus 向量數據庫&#xff0c;可以使用官方提供的 Milvus Web UI 工具&#xff0c;這是一款可視化管理界面&#xff0c;支持查看集合、向量數據、執行基本操作等功能。以下是具體的部署和訪問方法&#xff1a; 一、部署 Milv…

Linux-awk與sed

文章目錄一、AWK1. awk 是什么&#xff1f;2. awk 的基礎語法2.1 選項2.2 模式2.3 動作3. awk 的內置變量4. 典型應用場景及示例4.1 打印特定列4.2 條件篩選4.3 使用正則表達式4.4 統計行數4.5 字段操作4.6 使用內置函數4.7 多文件處理4.8 使用自定義變量5. 高級應用&#xff1…

文件加密工具(勒索病毒加密方式)

語言&#xff1a;C# WPF功能&#xff1a;文件加/解密本程序不提供下載&#xff0c;該程序新手操作不當&#xff0c;可能會導致文件加密后無法解密問題&#xff0c;解密需要獨立私鑰private.key文件支持&#xff0c;沒有私鑰加密文件是無法被解密的。更新&#xff1a;2025年7月3…

IOC實現原理源碼解析

Spring三級緩存流程圖singletonObjects&#xff08;一級緩存&#xff09;&#xff1a;緩存經過了完整生命周期的Bean&#xff1b;arlySingletonobjects&#xff08;二級緩存&#xff09;&#xff1a;緩存未經過完整生命周期的Bean&#xff0c;如果某個Bean出現了循環依賴&#…

筆記本電腦磁盤維護指南:WIN11系統磁盤維護完全手冊

1. 引言 在當今數字化時代,筆記本電腦已經成為我們工作、學習和娛樂不可或缺的重要工具。隨著Windows 11操作系統的普及和應用,用戶對于系統性能和穩定性的要求越來越高。然而,許多用戶往往忽視了一個至關重要的方面——磁盤維護。磁盤作為計算機系統中負責數據存儲和讀取的…

李宏毅2025《機器學習》-第九講:大型語言模型評測的困境與“古德哈特定律”**

摘要&#xff1a; 隨著大型語言模型&#xff08;LLM&#xff09;的推理能力日益增強&#xff0c;如何公平、準確地評測其“智力”水平&#xff0c;成了一個極其棘手的問題。本文基于李宏毅教授的最新課程&#xff0c;深入探討了當前LLM評測面臨的困境。文章首先揭示了標準數學和…

Spring Boot集成Chaos Monkey:構建高韌性系統的故障注入實戰指南

Spring Boot集成Chaos Monkey&#xff1a;構建高韌性系統的故障注入實戰指南一、Chaos Engineering核心原理1.1 混沌工程價值矩陣1.2 Chaos Monkey核心攻擊類型二、Spring Boot集成Chaos Monkey2.1 基礎集成配置依賴引入配置文件 - application.yml2.2 高級攻擊策略配置自定義攻…

AtCoder Beginner Contest 416(ABCDE)

A - Vacation Validation 翻譯&#xff1a; 給你一個長度為 N 的字符串 S&#xff0c;它由 o 和 x 以及整數 L 和 R 組成。 請判斷 S 中從第 L 個字符到第 R 個字符的所有字符是否都是 o。 思路&#xff1a; &#xff08;模擬&#xff09; 實現&#xff1a; #include<bits…

【AlphaFold3】網絡架構篇(2)|Input Embedding 對輸入進行特征嵌入

博主簡介&#xff1a;努力學習的22級計算機科學與技術本科生一枚&#x1f338;博主主頁&#xff1a; Yaoyao2024往期回顧&#xff1a;【AlphaFold3】網絡架構篇&#xff08;1&#xff09;|概覽預測算法每日一言&#x1f33c;: 去留無意&#xff0c;閑看庭前花開花落&#xff1b…

秋招Day20 - 微服務 - 概念

什么是微服務&#xff1f;將一個大型的單體項目分割成一個個可以獨立開發和部署的小服務&#xff0c;服務之間松耦合&#xff0c;可以通過輕量級通信機制&#xff08;比如HTTP&#xff09;相互協作微服務帶來了哪些挑戰&#xff1f; 介紹一下一下Dubbo&#xff1f;Dubbo是一個高…