詳解react-router-dom v6版本基本使用介紹
Routes
- 代替Switch組件,不會(huì)向下匹配
- 用來(lái)包裹Route
Route
- 必須被Routes組件包裹
- component屬性變成element
- caseSensitive 路徑大小寫(xiě)敏感屬性,默認(rèn)是不敏感(訪問(wèn)/about = /ABOUT)
- index 與path屬性是互斥的,index表示為當(dāng)前路由的根
- 可以用作layout組件,不寫(xiě)element屬性,寫(xiě)了要與 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
- 用來(lái)代替Redirect組件
- replace屬性 跳轉(zhuǎn)模式 "PUSH" | "REPLACE"
- 只要這個(gè)組件一渲染就會(huì)發(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ū)分大小寫(xiě)
useRoutes
用來(lái)管理路由表,相比v5,可能需要借助一些第三方庫(kù)來(lái)實(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會(huì)防到父親的位置,所以不需要配合Outlet組件使用 ? ? ? ? } ? ? ? ] ? ? } ? ])
嵌套路由
嵌套路由一般是配合 Outlet 組件使用,此組件類(lèi)似于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對(duì)象,如果直接輸入可能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> 返回上一頁(yè) <button *onClick*={() => navigate(1)}>go</button> 前進(jìn)
其他一些hooks
- useInRouterContext 判斷組件是否被Router包裹,可能有些第三方組件需要判斷
- useNavigationType 返回用戶到當(dāng)前頁(yè)面的導(dǎo)航類(lèi)型 "POP" | "PUSH" | "REPLACE";
- 注意 POP是指在瀏覽器直接打開(kāi)了這個(gè)路由組件(刷新頁(yè)面)
- useOutlet 返回嵌套的路由,可以代替Outlet組件
- useResolvedPath 給定一個(gè)url,解析出path,hash,search(location對(duì)象)
到此這篇關(guān)于詳解react-router-dom v6版本基本使用介紹的文章就介紹到這了,更多相關(guān)react-router-dom v6使用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- react-router-dom?v6?通過(guò)outlet實(shí)現(xiàn)keepAlive?功能的實(shí)現(xiàn)
- react-router-domV6版本的路由和嵌套路由寫(xiě)法詳解
- 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ò)程
相關(guān)文章
React-Router v6實(shí)現(xiàn)頁(yè)面級(jí)按鈕權(quán)限示例詳解
這篇文章主要介紹了使用 reac+reactRouter來(lái)實(shí)現(xiàn)頁(yè)面級(jí)的按鈕權(quán)限功能,這篇文章分三部分,實(shí)現(xiàn)思路、代碼實(shí)現(xiàn)、踩坑記錄,有需要的朋友可以借鑒參考下,希望能夠有所幫助2023-10-10React跨路由組件動(dòng)畫(huà)實(shí)現(xiàn)
在 React 中路由之前的切換動(dòng)畫(huà)可以使用 react-transition-group 來(lái)實(shí)現(xiàn),但對(duì)于不同路由上的組件如何做到動(dòng)畫(huà)過(guò)渡是個(gè)很大的難題,目前社區(qū)中也沒(méi)有一個(gè)成熟的方案,本文給大家分享React跨路由組件動(dòng)畫(huà)實(shí)現(xiàn),感興趣的朋友一起看看吧2023-10-10react-router 路由切換動(dòng)畫(huà)的實(shí)現(xiàn)示例
這篇文章主要介紹了react-router 路由切換動(dòng)畫(huà)的實(shí)現(xiàn)示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-12-12react的ui庫(kù)antd中form表單使用SelectTree反顯問(wèn)題及解決
這篇文章主要介紹了react的ui庫(kù)antd中form表單使用SelectTree反顯問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-01-01React文件名和目錄規(guī)范最佳實(shí)踐記錄(總結(jié)篇)
React在使用時(shí)非常靈活,如果沒(méi)有一個(gè)規(guī)范約束項(xiàng)目,在開(kāi)發(fā)過(guò)程中會(huì)非?;靵y,本文將介紹幾個(gè)優(yōu)秀的規(guī)范,介紹文件名和目錄前,需要先簡(jiǎn)述一下幾種通用的類(lèi)型,用來(lái)區(qū)分文件的功能,感興趣的朋友一起看看吧2022-05-05React?狀態(tài)管理工具優(yōu)劣勢(shì)示例分析
這篇文章主要為大家介紹了React?狀態(tài)管理工具優(yōu)劣勢(shì)示例分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-01-01使用React實(shí)現(xiàn)內(nèi)容滑動(dòng)組件效果
這篇文章主要介紹了使用React實(shí)現(xiàn)一個(gè)內(nèi)容滑動(dòng)組件效果,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-05-05React中Suspense及l(fā)azy()懶加載及代碼分割原理和使用方式
這篇文章主要介紹了React中Suspense及l(fā)azy()懶加載及代碼分割原理和使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09