欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解react-router-dom v6版本基本使用介紹

 更新時(shí)間:2022年03月11日 09:13:35   作者:Rise_11  
本文主要介紹了react-router-dom v6版本基本使用介紹,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

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)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • React-Router v6實(shí)現(xiàn)頁面級按鈕權(quán)限示例詳解

    React-Router v6實(shí)現(xiàn)頁面級按鈕權(quán)限示例詳解

    這篇文章主要介紹了使用 reac+reactRouter來實(shí)現(xiàn)頁面級的按鈕權(quán)限功能,這篇文章分三部分,實(shí)現(xiàn)思路、代碼實(shí)現(xiàn)、踩坑記錄,有需要的朋友可以借鑒參考下,希望能夠有所幫助
    2023-10-10
  • react-diagram 序列化Json解讀案例分析

    react-diagram 序列化Json解讀案例分析

    今天帶來大家學(xué)習(xí)react-diagram 序列化Json解讀的相關(guān)知識,本文通過多種案例給大家分析序列化知識,通過圖文并茂的形式給大家介紹的非常詳細(xì),感興趣的朋友一起看看吧
    2021-05-05
  • React跨路由組件動畫實(shí)現(xiàn)

    React跨路由組件動畫實(shí)現(xiàn)

    在 React 中路由之前的切換動畫可以使用 react-transition-group 來實(shí)現(xiàn),但對于不同路由上的組件如何做到動畫過渡是個(gè)很大的難題,目前社區(qū)中也沒有一個(gè)成熟的方案,本文給大家分享React跨路由組件動畫實(shí)現(xiàn),感興趣的朋友一起看看吧
    2023-10-10
  • 基于react組件之間的參數(shù)傳遞(詳解)

    基于react組件之間的參數(shù)傳遞(詳解)

    下面小編就為大家?guī)硪黄趓eact組件之間的參數(shù)傳遞(詳解)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-09-09
  • react-router 路由切換動畫的實(shí)現(xiàn)示例

    react-router 路由切換動畫的實(shí)現(xiàn)示例

    這篇文章主要介紹了react-router 路由切換動畫的實(shí)現(xiàn)示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-12-12
  • react的ui庫antd中form表單使用SelectTree反顯問題及解決

    react的ui庫antd中form表單使用SelectTree反顯問題及解決

    這篇文章主要介紹了react的ui庫antd中form表單使用SelectTree反顯問題及解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • React文件名和目錄規(guī)范最佳實(shí)踐記錄(總結(jié)篇)

    React文件名和目錄規(guī)范最佳實(shí)踐記錄(總結(jié)篇)

    React在使用時(shí)非常靈活,如果沒有一個(gè)規(guī)范約束項(xiàng)目,在開發(fā)過程中會非常混亂,本文將介紹幾個(gè)優(yōu)秀的規(guī)范,介紹文件名和目錄前,需要先簡述一下幾種通用的類型,用來區(qū)分文件的功能,感興趣的朋友一起看看吧
    2022-05-05
  • React?狀態(tài)管理工具優(yōu)劣勢示例分析

    React?狀態(tài)管理工具優(yōu)劣勢示例分析

    這篇文章主要為大家介紹了React?狀態(tài)管理工具優(yōu)劣勢示例分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-01-01
  • 使用React實(shí)現(xiàn)內(nèi)容滑動組件效果

    使用React實(shí)現(xiàn)內(nèi)容滑動組件效果

    這篇文章主要介紹了使用React實(shí)現(xiàn)一個(gè)內(nèi)容滑動組件效果,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-05-05
  • React中Suspense及l(fā)azy()懶加載及代碼分割原理和使用方式

    React中Suspense及l(fā)azy()懶加載及代碼分割原理和使用方式

    這篇文章主要介紹了React中Suspense及l(fā)azy()懶加載及代碼分割原理和使用方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09

最新評論