詳解react-router-dom v6版本基本使用介紹
Routes
- 代替Switch組件,不會向下匹配
- 用來包裹Route
Route
- 必須被Routes組件包裹
- component屬性變成element
- caseSensitive 路徑大小寫敏感屬性,默認(rèn)是不敏感(訪問/about = /ABOUT)
- index 與path屬性是互斥的,index表示為當(dāng)前路由的根
- 可以用作layout組件,不寫element屬性,寫了要與 Outlet組件配合使用(嵌套路由)
? ? ? ? <Routes> ? ? ? ? ? <Route path='/home' element={<Home />}></Route> ? ? ? ? ? <Route path='/about' element={<About />} caseSensitive={false} /> ? ? ? ? </Routes> ? ? ? ? <Route path='/user'> ? ? ? ? ? ? <Route index element={<h1>user~</h1>} /> ? ? ? ? </Route>
Navigate
- 用來代替Redirect組件
- replace屬性 跳轉(zhuǎn)模式 "PUSH" | "REPLACE"
- 只要這個(gè)組件一渲染就會發(fā)生跳轉(zhuǎn)
? ? ? ? <Routes> ? ? ? ? ? <Route path='/home' element={<Home />}></Route> ? ? ? ? ? <Route path='/about' element={<About />} caseSensitive={false} /> ? ? ? ? ? <Route path='*' element={<Navigate to='/home' />} /> ? ? ? ? </Routes>
NavLink
- className,自定義激活時(shí)的樣式名 可以為字符串或者函數(shù)
- end 匹配子路由時(shí)是否高亮
- caseSensitive 代表匹配路徑時(shí)是否區(qū)分大小寫
useRoutes
用來管理路由表,相比v5,可能需要借助一些第三方庫來實(shí)現(xiàn)路由config管理,現(xiàn)在v6版本自帶
const routes = useRoutes([ ? ? { ? ? ? path: '/home', ? ? ? element: <Home /> ? ? }, ? ? { ? ? ? path: '/about', ? ? ? element: <About /> ? ? }, ? ? { ? ? ? path: '*', ? ? ? element: <Navigate to='/home' /> ? ? }, ? ? { ? ? ? path: '/user', ? ? ? children: [ ? ? ? ? { ? ? ? ? ? index: true, ? ? ? ? ? element: <h1>user~</h1> // 這種不屬于嵌套路由,這里面children會防到父親的位置,所以不需要配合Outlet組件使用 ? ? ? ? } ? ? ? ] ? ? } ? ])
嵌套路由
嵌套路由一般是配合 Outlet 組件使用,此組件類似于Vue的router-view組件,告知子路由應(yīng)該渲染在什么位置
{ ? ? ? path: '/home', ? ? ? element: <Home />, // 這種才屬于嵌套路由 ? ? ? children: [ ? ? ? ? { ? ? ? ? ? path: 'message', ? ? ? ? ? element: <Message /> ? ? ? ? }, ? ? ? ? { ? ? ? ? ? path: 'article', ? ? ? ? ? element: <Article /> ? ? ? ? } ? ? ? ] }
在Home組件中使用<Outlet/>才能渲染子路由
? ? ? <div style={{ marginTop: '48px' }}> ? ? ? ? <div className='nav'> ? ? ? ? ? <div className='nav-item'> ? ? ? ? ? ? <NavLink to='/home/message'>message</NavLink> ? ? ? ? ? </div> ? ? ? ? ? <div className='nav-item'> ? ? ? ? ? ? <NavLink to='/home/article'>article</NavLink> ? ? ? ? ? </div> ? ? ? ? ? <div style={{ marginTop: 36 }}> ? ? ? ? ? ? <Outlet /> ? ? ? ? ? ? {/* {outlet} */} ? ? ? ? ? </div> ? ? ? ? </div> ? ? ? </div>
路由傳參
- params傳參(useParams)
- search參數(shù)傳參(useSearchParams)
- state傳參 (useLocation,獲取v5版本的location對象,如果直接輸入可能state為null)
編程式導(dǎo)航
useNavigate
const navigate = useNavigate() navigate('detail3', { state: { id: *item*.id, content: *item*.content, title: *item*.title } }) <button *onClick*={() => navigate(-1)}>back</button> 返回上一頁 <button *onClick*={() => navigate(1)}>go</button> 前進(jìn)
其他一些hooks
- useInRouterContext 判斷組件是否被Router包裹,可能有些第三方組件需要判斷
- useNavigationType 返回用戶到當(dāng)前頁面的導(dǎo)航類型 "POP" | "PUSH" | "REPLACE";
- 注意 POP是指在瀏覽器直接打開了這個(gè)路由組件(刷新頁面)
- useOutlet 返回嵌套的路由,可以代替Outlet組件
- useResolvedPath 給定一個(gè)url,解析出path,hash,search(location對象)
到此這篇關(guān)于詳解react-router-dom v6版本基本使用介紹的文章就介紹到這了,更多相關(guān)react-router-dom v6使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- react-router-dom?v6?通過outlet實(shí)現(xiàn)keepAlive?功能的實(shí)現(xiàn)
- react-router-domV6版本的路由和嵌套路由寫法詳解
- react-router6.x路由配置及導(dǎo)航詳解
- React路由規(guī)則定義與聲明式導(dǎo)航及編程式導(dǎo)航分別介紹
- React路由渲染方式與withRouter高階組件及自定義導(dǎo)航組件應(yīng)用詳細(xì)介紹
- React Native中導(dǎo)航組件react-navigation跨tab路由處理詳解
- 使用 React Router Dom 實(shí)現(xiàn)路由導(dǎo)航的詳細(xì)過程
相關(guān)文章
React-Router v6實(shí)現(xiàn)頁面級按鈕權(quán)限示例詳解
這篇文章主要介紹了使用 reac+reactRouter來實(shí)現(xiàn)頁面級的按鈕權(quán)限功能,這篇文章分三部分,實(shí)現(xiàn)思路、代碼實(shí)現(xiàn)、踩坑記錄,有需要的朋友可以借鑒參考下,希望能夠有所幫助2023-10-10react-router 路由切換動畫的實(shí)現(xiàn)示例
這篇文章主要介紹了react-router 路由切換動畫的實(shí)現(xiàn)示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-12-12react的ui庫antd中form表單使用SelectTree反顯問題及解決
這篇文章主要介紹了react的ui庫antd中form表單使用SelectTree反顯問題及解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-01-01React文件名和目錄規(guī)范最佳實(shí)踐記錄(總結(jié)篇)
React在使用時(shí)非常靈活,如果沒有一個(gè)規(guī)范約束項(xiàng)目,在開發(fā)過程中會非常混亂,本文將介紹幾個(gè)優(yōu)秀的規(guī)范,介紹文件名和目錄前,需要先簡述一下幾種通用的類型,用來區(qū)分文件的功能,感興趣的朋友一起看看吧2022-05-05使用React實(shí)現(xiàn)內(nèi)容滑動組件效果
這篇文章主要介紹了使用React實(shí)現(xiàn)一個(gè)內(nèi)容滑動組件效果,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-05-05React中Suspense及l(fā)azy()懶加載及代碼分割原理和使用方式
這篇文章主要介紹了React中Suspense及l(fā)azy()懶加載及代碼分割原理和使用方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09