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

React router基礎(chǔ)使用方法詳解

 更新時(shí)間:2023年04月22日 08:30:51   作者:葉落風(fēng)塵  
這篇文章主要介紹了React router基礎(chǔ)使用方法,React Router是React生態(tài)系統(tǒng)中最受歡迎的第三方庫之一,近一半的React項(xiàng)目中使用了React Router,下面就來看看如何在React項(xiàng)目中使用

react-router

1、使用方法

<Router history={hashHistory}>
 <Route path="/" component={App}/>
 <Route path="/repos" component={Repos}/>
 <Route path="/about" component={About}/>
</Router>

2、嵌套路由、path、通配符

Route 可以嵌套使用。

path 屬性指定路由的匹配規(guī)則。

<Router history={hashHistory}>
 <Route path="/user" component={App}>
  <Route path="/repos" component={Repos}/>
  <Route path="/about" component={About}/>
 </Route>
</Router>
<Route path="/hello/:name">

// :paramName 匹配 URL 的一個(gè)部分,直到遇到下一個(gè)/、?、#為止。

// 匹配 /hello/michael

// 匹配 /hello/ryan

<Route path="/hello(/:name)"> // ()表示 URL 的這個(gè)部分是可選的。

// 匹配 /hello

// 匹配 /hello/michael

// 匹配 /hello/ryan

<Route path="/files/*.*"> // *匹配任意字符,直到模式里面的下一個(gè)字符為止。匹配方式是非貪婪模式。

// 匹配 /files/hello1.jpg

// 匹配 /files/hello2.html

<Route path="/files/*"> 

// 匹配 /files/a

// 匹配 /files/a/b

<Route path="/files/**"> // ** 匹配任意字符,直到下一個(gè)/、?、#為止。匹配方式是貪婪模式。

// 匹配 /files/a

// 匹配 /files/indexa

3、histroy 屬性

Router 組件的 history 屬性,用來監(jiān)聽瀏覽器地址欄的變化,并將 URL 解析成一個(gè)地址對(duì)象,供 React Router 匹配。

history 屬性,常用的 2 種:

(1).hashHistory

如果設(shè)為 hashHistory,路由將通過 URL 的 hash 部分(#)切換,URL 的形式類似 example.com/#/user/user1。使用 hashHistory 的時(shí)候,因?yàn)?url 中 # 符號(hào)的存在,從 /#/ 到 /#/user?name=zhangsan 瀏覽器并不會(huì)去發(fā)送一次 request,react-router 自己根據(jù) url 去 render 相應(yīng)的模塊。

browserHistory

如果設(shè)為 browserHistory,瀏覽器的路由就不再通過 Hash 完成了,而顯示正常的路徑:example.com/some/path,背后調(diào)用的是瀏覽器的 History API。

使用 browserHistory 的時(shí)候,瀏覽器從 / 到 /user 是會(huì)向 server 發(fā)送 request 的。所以 server 端是要做特殊配置的;否則用戶直接向服務(wù)器請(qǐng)求某個(gè)子路由,會(huì)顯示網(wǎng)頁找不到的 404 錯(cuò)誤。

import { browserHistory } from 'react-router'
render(
 <Router history={browserHistory} routes={routes} />,
 document.getElementById('app')
)

ReachRouter

Reach Router 也提供了 Router 與 Link 組件,和 React Router 不同,它將直接將對(duì)應(yīng)的組件寫在 Router 組件下,而不是,這么做無疑大大簡(jiǎn)化了邏輯。

import { React } from "react"
import { render } from "react-dom"
import { Router, Link } from "@reach/router"
let Home = () => <div>Home</div>
let Dash = () => <div>Dash</div>
render(
 <Router>
  <Home path="/" />
  <Dash path="dashboard" />
 </Router>
)

Reach Router 的參數(shù)接收方法就好像是直接給這個(gè)組件傳遞了參數(shù)的 Props 一樣,比 React Router 方便很多。

<Home path='/user/:id'>
const Home = ({id})=>{
  return (
    <span>{id}</span>
  )
}

Reach Router 渲染有一個(gè)策略,一個(gè)路由下只會(huì)渲染一個(gè)最符合條件的路由。

嵌套路由

render(
 <Router>
  <Home path="/" />
  <Dash path="dashboard">
   <Invoices path="/invoices" />
   <Team path="team" />
  </Dash>
 </Router>
)
const NotFound = () => (
 <div>Sorry, nothing here.</div>
)
render(
 <Router>
  <Home path="/" />
  <Dash path="dashboard">
   <DashboardGraphs path="/" />
   <InvoiceList path="invoices" />
  </Dash>
  <NotFound default />
 </Router>
)

到此這篇關(guān)于React router基礎(chǔ)使用方法詳解的文章就介紹到這了,更多相關(guān)React router內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • React中如何引入Angular組件詳解

    React中如何引入Angular組件詳解

    這篇文章主要給大家介紹了關(guān)于React中如何引入Angular組件的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-08-08
  • react-router-dom v6版本實(shí)現(xiàn)Tabs路由緩存切換功能

    react-router-dom v6版本實(shí)現(xiàn)Tabs路由緩存切換功能

    今天有人問我怎么實(shí)現(xiàn)React-Router-dom類似標(biāo)簽頁緩存,很久以前用的是react-router v5那個(gè)比較容易實(shí)現(xiàn),v6變化挺大,但了解react的機(jī)制和react-router的機(jī)制就容易了,本文介紹react-router-dom v6版本實(shí)現(xiàn)Tabs路由緩存切換,感興趣的朋友一起看看吧
    2023-10-10
  • Remix路由模塊輸出對(duì)象loader函數(shù)詳解

    Remix路由模塊輸出對(duì)象loader函數(shù)詳解

    這篇文章主要為大家介紹了Remix路由模塊輸出對(duì)象loader函數(shù)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪<BR>
    2023-04-04
  • 使用react-native-doc-viewer實(shí)現(xiàn)文檔預(yù)覽

    使用react-native-doc-viewer實(shí)現(xiàn)文檔預(yù)覽

    這篇文章主要介紹了使用react-native-doc-viewer實(shí)現(xiàn)文檔預(yù)覽,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • React事件處理超詳細(xì)介紹

    React事件處理超詳細(xì)介紹

    這篇文章主要介紹了React事件處理,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-09-09
  • React項(xiàng)目中不需要jQuery原因分析

    React項(xiàng)目中不需要jQuery原因分析

    在Web開發(fā)的早期,jQuery是一個(gè)革命性的庫,它極大地簡(jiǎn)化了DOM操作、事件處理、動(dòng)畫制作以及Ajax請(qǐng)求等任務(wù),React的出現(xiàn),jQuery在新項(xiàng)目中的必要性開始受到質(zhì)疑,本文將探討為什么在React應(yīng)用中不需要jQuery,感興趣的朋友可以參考下
    2024-02-02
  • React.Children的用法詳解

    React.Children的用法詳解

    這篇文章主要介紹了React.Children的用法詳解,幫助大家更好的理解和學(xué)習(xí)使用React框架,感興趣的朋友可以了解下
    2021-04-04
  • React?性能優(yōu)化方法總結(jié)

    React?性能優(yōu)化方法總結(jié)

    這篇文章主要介紹了React性能優(yōu)化方法總結(jié),文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-09-09
  • React 全自動(dòng)數(shù)據(jù)表格組件——BodeGrid的實(shí)現(xiàn)思路

    React 全自動(dòng)數(shù)據(jù)表格組件——BodeGrid的實(shí)現(xiàn)思路

    表格是在后臺(tái)管理系統(tǒng)中用的最頻繁的組件之一,相關(guān)的功能有數(shù)據(jù)的新增和編輯、查詢、排序、分頁、自定義顯示以及一些操作按鈕。這篇文章主要介紹了React 全自動(dòng)數(shù)據(jù)表格組件——BodeGrid ,需要的朋友可以參考下
    2019-06-06
  • react配置antd按需加載的使用

    react配置antd按需加載的使用

    這篇文章主要介紹了react配置antd按需加載的使用,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2019-02-02

最新評(píng)論