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

react-router-dom?v6?使用詳細(xì)示例

 更新時(shí)間:2022年09月12日 09:02:48   作者:日拱一寸  
這篇文章主要介紹了react-router-dom?v6使用詳細(xì)示例,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,感興趣的小伙伴可以參考一下,希望對(duì)你的學(xué)習(xí)有所幫助

一、基本使用

首先安裝依賴:

npm i react-router-dom

引入實(shí)現(xiàn)路由所需的組件,以及頁(yè)面組件:

import { BrowserRouter, Routes, Route } from "react-router-dom";
import Foo from "./Foo";
import Bar from "./Bar";
function App() {
  return (
    <BrowserRouter>
      <Routes>
        <Route path="/foo" element={<Foo />} />
        <Route path="/bar" element={<Bar />} />
      </Routes>
    </BrowserRouter>
  );
}
  • path:路徑
  • element:要渲染的組件

注意BrowserRouter組件最好放在最頂層所有組件之外,這樣能確保內(nèi)部組件使用 Link 做路由跳轉(zhuǎn)時(shí)不出錯(cuò)

二、路由跳轉(zhuǎn)

在跳轉(zhuǎn)路由時(shí),如果路徑是/開頭的則是絕對(duì)路由,否則為相對(duì)路由,即相對(duì)于當(dāng)前 URL進(jìn)行改變

2.1 Link 組件

Link組件只能在Router內(nèi)部使用,因此使用到Link組件的組件一定要放在頂層的 Router 之內(nèi)

import { Link } from "react-router-dom";

<Link to="foo">to foo</Link>;

2.2 NavLink 組件

  • NavLink組件Link組件的功能是一致的,區(qū)別在于可以判斷其to屬性是否是當(dāng)前匹配到的路由
  • NavLink組件styleclassName可以接收一個(gè)函數(shù),函數(shù)接收一個(gè)含有isActive字段的對(duì)象為參數(shù),可根據(jù)該參數(shù)調(diào)整樣式
import { NavLink } from "react-router-dom";

function Foo() {
  return (
    <NavLink style={({ isActive }) => ({ color: isActive ? "red" : "#fff" })}>
      Click here
    </NavLink>
  );
}

2.3 編程式跳轉(zhuǎn)

使用useNavigate鉤子函數(shù)生成navigate函數(shù),可以通過 JS 代碼完成路由跳轉(zhuǎn)

useNavigate取代了原先版本中的useHistory

import { useNavigate } from 'react-router-dom';

function Foo(){
    const navigate = useNavigate();
    return (
        // 上一個(gè)路徑:/a;    當(dāng)前路徑: /a/a1
        <div onClick={() => navigate('/b')}>跳轉(zhuǎn)到/b</div>
        <div onClick={() => navigate('a11')}>跳轉(zhuǎn)到/a/a1/a11</div>
        <div onClick={() => navigate('../a2')}>跳轉(zhuǎn)到/a/a2</div>
        <div onClick={() => navigate(-1)}>跳轉(zhuǎn)到/a</div>
    )
}
  • 可以直接傳入要跳轉(zhuǎn)的目標(biāo)路由(可以使用相對(duì)路徑,語法和 JS 相同)
  • 傳入-1表示后退

三、動(dòng)態(tài)路由參數(shù)

3.1 路徑參數(shù)

  • Route組件中的path屬性中定義路徑參數(shù)
  • 在組件內(nèi)通過useParams hook 訪問路徑參數(shù)
<BrowserRouter>
  <Routes>
    <Route path="/foo/:id" element={<Foo />} />
  </Routes>
</BrowserRouter>;

import { useParams } from "react-router-dom";
export default function Foo() {
  const params = useParams();
  return (
    <div>
      <h1>{params.id}</h1>
    </div>
  );
}

路徑匹配規(guī)則

當(dāng)URL同時(shí)匹配到含有路徑參數(shù)的路徑和無參數(shù)路徑時(shí),有限匹配沒有參數(shù)的”具體的“(specific)路徑。

<Route path="teams/:teamId" element={<Team />} />
<Route path="teams/new" element={<NewTeamForm />} />

如上的兩個(gè)路徑,將會(huì)匹配 teams/new 。

路徑的正則匹配已被移除。

兼容類組件

在以前版本中,組件的props會(huì)包含一個(gè)match對(duì)象,在其中可以取到路徑參數(shù)。

但在最新的 6.x 版本中,無法從 props 獲取參數(shù)。

并且,針對(duì)類組件的 withRouter 高階組件已被移除。因此對(duì)于類組件來說,使用參數(shù)有兩種兼容方法:

  • 將類組件改寫為函數(shù)組件
  • 自己寫一個(gè) HOC 來包裹類組件,用 useParams 獲取參數(shù)后通過 props 傳入原本的類組件

3.2 search 參數(shù)

  • 查詢參數(shù)不需要在路由中定義
  • 使用 useSearchParams hook 來訪問和修改查詢參數(shù)。其用法和 useState 類似,會(huì)返回當(dāng)前對(duì)象和更改它的方法
  • 使用 setSearchParams 時(shí),必須傳入所有的查詢參數(shù),否則會(huì)覆蓋已有參數(shù)
import { useSearchParams } from "react-router-dom";

// 當(dāng)前路徑為 /foo?id=12
function Foo() {
  const [searchParams, setSearchParams] = useSearchParams();
  console.log(searchParams.get("id")); // 12
  setSearchParams({
    name: "foo",
  }); // /foo?name=foo
  return <div>foo</div>;
}

四、嵌套路由

5.1 路由定義

通過嵌套的書寫Route組件實(shí)現(xiàn)對(duì)嵌套路由的定義。

path 開頭為 / 的為絕對(duì)路徑,反之為相對(duì)路徑。

<Routes>
  <Route path="/" element={<Home />}></Route>
  <Route path="/father" element={<Father />}>
    <Route path="child" element={<Child />}></Route>
    <Route path=":name" element={<Another />}></Route>
  </Route>
</Routes>

5.2 在父組件中展示

在父組件中使用Outlet來顯示匹配到的子組件

import { Outlet } from "react-router-dom";
function Father() {
  return (
    <div>
      // ... 自己組件的內(nèi)容 // 留給子組件Child的出口
      <Outlet />
    </div>
  );
}

5.3 在組件中定義

可以在任何組件中使用 Routes 組件,且組件內(nèi)的Routes中,路徑默認(rèn)帶上當(dāng)前組件的路徑作為前綴。

注意:此時(shí)定義父組件的路由時(shí),要在后面加上 /* ,否則父組件將無法渲染。

<Routes>
  <Route path="/" element={<Home />} />
  <Route path="dashboard/*" element={<Dashboard />} />
</Routes>
function Dashboard() {
  return (
    <div>
      <p>Look, more routes!</p>
      <Routes>
        <Route path="/" element={<DashboardGraphs />} />
        <Route path="invoices" element={<InvoiceList />} />
      </Routes>
    </div>
  );
}

五、默認(rèn)路由

定義: 在嵌套路由中,如果 URL 僅匹配了父級(jí) URL,則Outlet中會(huì)顯示帶有index屬性的子路由。可以使用在路由的任何層級(jí)

<Routes>
  <Route path="/foo" element={Foo}>
    <Route index element={Default}></Route>
    <Route path="bar" element={Bar}></Route>
  </Route>
</Routes>
  • 當(dāng) url 為/foo時(shí):Foo 中的 Outlet 會(huì)顯示 Default 組件
  • 當(dāng) url 為/foo/bar時(shí):Foo 中的 Outlet 會(huì)顯示為 Bar 組件

六、全匹配路由

定義:  path屬性取值為*時(shí),可以匹配任何(非空)路徑,該匹配擁有最低的優(yōu)先級(jí)??梢杂糜谠O(shè)置 404 頁(yè)面。

<Routes>
  <Route path="/foo" element={Foo}>
    <Route path="bar" element={Bar}></Route>
    <Route path="*" element={NotFound}></Route>
  </Route>
</Routes>

七、多組路由

通常,一個(gè)應(yīng)用中只有一個(gè)Routes組件。

但根據(jù)實(shí)際需要也可以定義多個(gè)路由出口(如:側(cè)邊欄和主頁(yè)面都要隨 URL 而變化)

<Router>
  <SideBar>
    <Routes>
      <Route></Route>
    </Routes>
  </SideBar>
  <Main>
    <Routes>
      <Route></Route>
    </Routes>
  </Main>
</Router>

八、路由重定向

當(dāng)在某個(gè)路徑/a下,要重定向到路徑/b時(shí),可以通過Navigate組件進(jìn)行重定向到其他路徑

等價(jià)于以前版本中的Redirect組件

import { Navigate } from "react-router-dom";
function A() {
  return <Navigate to="/b" />;
}

九、布局路由

當(dāng)多個(gè)路由有共同的父級(jí)組件時(shí),可以將父組件提取為一個(gè)沒有 path 和 index 屬性的Route組件(Layout Route)

<Route element={<PageLayout />}>
    <Route path="/privacy" element={<Privacy />} />
    <Route path="/tos" element={<Tos />} />
  </Route>

這種寫法等價(jià)于:

<Route
  path="/privacy"
  element={
    <PageLayout>
      <Privacy />
    </PageLayout>
  }
/>
<Route
  path="/tos"
  element={
    <PageLayout>
      <Tos />
    </PageLayout>
  }
/>

十、訂閱和操作 history stack的原理

瀏覽器會(huì)記錄導(dǎo)航堆棧,以實(shí)現(xiàn)瀏覽器中的前進(jìn)后退功能。在傳統(tǒng)的前端項(xiàng)目中,URL的改變意味著向服務(wù)器重新請(qǐng)求數(shù)據(jù)。

在現(xiàn)在的客戶端路由( client side routing )中,可以做到編程控制URL改變后的反應(yīng)。如在點(diǎn)擊a標(biāo)簽的回調(diào)函數(shù)中使用 event.preventDefault() 阻止默認(rèn)事件,此時(shí)URL的改變不會(huì)帶來任何UI上的更新。

<a
  href="/contact" rel="external nofollow" 
  onClick={(event) => {
    // stop the browser from changing the URL and requesting the new document
    event.preventDefault();
    // push an entry into the browser history stack and change the URL
    window.history.pushState({}, undefined, "/contact");
  }}
/>

10.1 History對(duì)象

瀏覽器沒有直接提供監(jiān)聽URL改變(push、pop、replace)的接口,因此 react-router 對(duì)原生的 history 對(duì)線進(jìn)行了包裝,提供了監(jiān)聽URL改變的API。

let history = createBrowserHistory();
history.listen(({ location, action }) => {
  // this is called whenever new locations come in
  // the action is POP, PUSH, or REPLACE
});

使用 react-router 時(shí)不需操作History對(duì)象(Routes 組件會(huì)進(jìn)行操作)

11.2 Location對(duì)象

react-router 對(duì) window.location 進(jìn)行包裝后,提供了一個(gè)形式簡(jiǎn)潔的Location對(duì)象,形如:

{
  pathname: "/bbq/pig-pickins",     // 主機(jī)名之后的URL地址
  search: "?campaign=instagram",    // 查詢參數(shù)
  hash: "#menu",                    // 哈希值,用于確定頁(yè)面滾動(dòng)的具體位置
  state: null,                      // 對(duì)于 window.history.state 的包裝
  key: "aefz24ie"                   // 
}

state

不顯示在頁(yè)面上,不會(huì)引起刷新,只由開發(fā)人員操作。

可用于記錄用戶的跳轉(zhuǎn)詳情(從哪跳到當(dāng)前頁(yè)面)或在跳轉(zhuǎn)時(shí)攜帶信息。

可以用在 Link 組件或 navigate 方法中

&lt;Link to="/pins/123" state={{ fromDashboard: true }} /&gt;
let navigate = useNavigate();
navigate("/users/123", { state: partialUser });
復(fù)制代碼

在目標(biāo)的組件中,可以用 useLocation 方法獲取該對(duì)象

let location = useLocation();
console.log(location.state);

state中的信息會(huì)進(jìn)行序列化,因此如日期對(duì)象等信息會(huì)變?yōu)閟tring

key

每個(gè)Location對(duì)象擁有一個(gè)唯一的key,可以據(jù)此來實(shí)現(xiàn)基于Location的滾動(dòng)管理,或是數(shù)據(jù)緩存。

如:將 location.key 和 URL 作為鍵,每次請(qǐng)求數(shù)據(jù)前,先查找緩存是否存在來判斷是否實(shí)際發(fā)送請(qǐng)求,來實(shí)現(xiàn)客戶端數(shù)據(jù)緩存。

十一、 各類Router組件

11.1 HashRouter和BrowserRouter的區(qū)別

  • HashRouter 只會(huì)修改URL中的哈希值部分;而 BrowserRouter 修改的是URL本身
  • HashRouter 是純前端路由,可以通過輸入U(xiǎn)RL直接訪問;使用時(shí) BrowserRouter 直接輸入U(xiǎn)RL會(huì)顯示404,除非配置Nginx將請(qǐng)求指向?qū)?yīng)的HTML文件。初次進(jìn)入 / 路徑時(shí)或點(diǎn)擊 Link 組件跳轉(zhuǎn)時(shí)不會(huì)發(fā)送請(qǐng)求

11.2 unstable_HistoryRouter

使用 unstable_HistoryRouter 需要傳入一個(gè) history 庫(kù)的實(shí)例,這將允許在非react作用于下操作history對(duì)象。

由于項(xiàng)目使用的history和react-router中使用的history版本可能不一樣,該API目前標(biāo)為unstable狀態(tài)

11.3 MemoryRouter

HashRouter 和 BrowserRouter 都是依據(jù)外部對(duì)象(history)進(jìn)行導(dǎo)航,而 MemoryRouter 則是自己存儲(chǔ)和管理狀態(tài)堆棧,多用于測(cè)試場(chǎng)景。

11.4 NativeRouter

推薦的用于 React Native的Router組件

11.5 StaticRouter

在nodejs端使用,渲染react應(yīng)用。

import * as React from "react";
import * as ReactDOMServer from "react-dom/server";
import { StaticRouter } from "react-router-dom/server";
import http from "http";

function requestHandler(req, res) {
  let html = ReactDOMServer.renderToString(
    <StaticRouter location={req.url}>
      {/* The rest of your app goes here */}
    </StaticRouter>
  );

  res.write(html);
  res.end();
}

http.createServer(requestHandler).listen(3000);

十二、使用JS對(duì)象定義路由:useRoutes

使用 useRoutes hook,可以使用一個(gè)JS對(duì)象而不是Routes組件與Route組件來定義路由。其功能類似于react-router-config

useRoutes 的返回是 React Element,或是 null。

對(duì)于傳入的配置對(duì)象, 其類型定義如下:

interface RouteObject {
    caseSensitive?: boolean;
    children?: RouteObject[];
    element?: React.ReactNode;
    index?: boolean;
    path?: string;
}

到此這篇關(guān)于react-router-dom v6 使用詳細(xì)示例的文章就介紹到這了,更多相關(guān)react-router-dom v6 內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • React之虛擬DOM的實(shí)現(xiàn)原理

    React之虛擬DOM的實(shí)現(xiàn)原理

    這篇文章主要介紹了React之虛擬DOM的實(shí)現(xiàn)原理分析,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • react入門級(jí)詳細(xì)筆記

    react入門級(jí)詳細(xì)筆記

    這篇文章講述了React的基本介紹,基本使用和React相關(guān)js庫(kù).通過這篇文章可以入門React的使用,可以快速上手使用React進(jìn)行代碼的編寫
    2021-06-06
  • React Mobx狀態(tài)管理工具的使用

    React Mobx狀態(tài)管理工具的使用

    這篇文章主要介紹了React Mobx狀態(tài)管理工具的使用,MobX是一個(gè)狀態(tài)管理庫(kù),它會(huì)自動(dòng)收集并追蹤依賴,開發(fā)人員不需要手動(dòng)訂閱狀態(tài),當(dāng)狀態(tài)變化之后MobX能夠精準(zhǔn)更新受影響的內(nèi)容,另外它不要求state是可JSON序列化的,也不要求state是immutable
    2023-02-02
  • JavaScript中React面向組件編程(上)

    JavaScript中React面向組件編程(上)

    本文主要介紹了React組件中默認(rèn)封裝了很多屬性,有的是提供給開發(fā)者操作的,其中有三個(gè)屬性非常重要:state、props、refs。感興趣的小伙伴可以參考閱讀
    2023-03-03
  • React hooks使用方法全面匯總

    React hooks使用方法全面匯總

    這篇文章主要介紹了react hooks實(shí)現(xiàn)原理,文中給大家介紹了useState dispatch函數(shù)如何與其使用的Function Component進(jìn)行綁定,實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-10-10
  • 用React-Native+Mobx做一個(gè)迷你水果商城APP(附源碼)

    用React-Native+Mobx做一個(gè)迷你水果商城APP(附源碼)

    這篇文章主要介紹了用React-Native+Mobx做一個(gè)迷你水果商城APP,功能需要的朋友可以參考下
    2017-12-12
  • 詳解在create-react-app使用less與antd按需加載

    詳解在create-react-app使用less與antd按需加載

    這篇文章主要介紹了詳解在create-react-app使用less與antd按需加載,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-12-12
  • 詳解react-navigation6.x路由庫(kù)的基本使用

    詳解react-navigation6.x路由庫(kù)的基本使用

    最近兩個(gè)項(xiàng)目都用到了React Navigation,所以就研究一下如何使用,本文主要介紹了react-navigation6.x路由庫(kù)的基本使用,感興趣的可以了解一下
    2021-11-11
  • 淺談React之狀態(tài)(State)

    淺談React之狀態(tài)(State)

    這篇文章主要介紹了淺談React之狀態(tài)(State),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-09-09
  • React文件名和目錄規(guī)范最佳實(shí)踐記錄(總結(jié)篇)

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

    React在使用時(shí)非常靈活,如果沒有一個(gè)規(guī)范約束項(xiàng)目,在開發(fā)過程中會(huì)非?;靵y,本文將介紹幾個(gè)優(yōu)秀的規(guī)范,介紹文件名和目錄前,需要先簡(jiǎn)述一下幾種通用的類型,用來區(qū)分文件的功能,感興趣的朋友一起看看吧
    2022-05-05

最新評(píng)論