詳解react-router-dom v6版本基本使用介紹
Routes
- 代替Switch組件,不會(huì)向下匹配
- 用來(lái)包裹Route
Route
- 必須被Routes組件包裹
- component屬性變成element
- caseSensitive 路徑大小寫敏感屬性,默認(rèn)是不敏感(訪問(wè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
- 用來(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ū)分大小寫
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 組件使用,此組件類似于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)航類型 "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版本的路由和嵌套路由寫法詳解
- 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)的權(quán)限控制實(shí)現(xiàn)示例
本文主要介紹了React-Router(V6)的權(quán)限控制實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-05-05
react?路由權(quán)限動(dòng)態(tài)菜單方案配置react-router-auth-plus
這篇文章主要為大家介紹了react路由權(quán)限動(dòng)態(tài)菜單方案react-router-auth-plus傻瓜式配置詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08
關(guān)于React項(xiàng)目中的PDF展示解決方案
這篇文章主要介紹了關(guān)于React項(xiàng)目中的PDF展示解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-07-07
使用React18和WebSocket構(gòu)建實(shí)時(shí)通信功能詳解
WebSocket是一種在Web應(yīng)用中實(shí)現(xiàn)雙向通信的協(xié)議,它允許服務(wù)器主動(dòng)向客戶端推送數(shù)據(jù),而不需要客戶端發(fā)起請(qǐng)求,本文將探索如何在React?18應(yīng)用中使用WebSocket來(lái)實(shí)現(xiàn)實(shí)時(shí)通信,感興趣的可以了解下2024-01-01
react redux中如何獲取store數(shù)據(jù)并將數(shù)據(jù)渲染出來(lái)
這篇文章主要介紹了react redux中如何獲取store數(shù)據(jù)并將數(shù)據(jù)渲染出來(lái),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08
React模仿網(wǎng)易云音樂(lè)實(shí)現(xiàn)一個(gè)音樂(lè)項(xiàng)目詳解流程
這篇文章主要介紹了React模仿網(wǎng)易云音樂(lè)實(shí)現(xiàn)一個(gè)音樂(lè)項(xiàng)目的詳細(xì)流程,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08

