91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

React?router基礎使用方法有哪些

發布時間:2023-05-06 15:40:58 來源:億速云 閱讀:130 作者:iii 欄目:開發技術

這篇“React router基礎使用方法有哪些”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“React router基礎使用方法有哪些”文章吧。

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 屬性指定路由的匹配規則。

<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 的一個部分,直到遇到下一個/、?、#為止。

// 匹配 /hello/michael

// 匹配 /hello/ryan

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

// 匹配 /hello

// 匹配 /hello/michael

// 匹配 /hello/ryan

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

// 匹配 /files/hello1.jpg

// 匹配 /files/hello2.html

<Route path="/files/*"> 

// 匹配 /files/a

// 匹配 /files/a/b

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

// 匹配 /files/a

// 匹配 /files/indexa

3、histroy 屬性

Router 組件的 history 屬性,用來監聽瀏覽器地址欄的變化,并將 URL 解析成一個地址對象,供 React Router 匹配。

history 屬性,常用的 2 種:

(1).hashHistory

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

browserHistory

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

使用 browserHistory 的時候,瀏覽器從 / 到 /user 是會向 server 發送 request 的。所以 server 端是要做特殊配置的;否則用戶直接向服務器請求某個子路由,會顯示網頁找不到的 404 錯誤。

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

ReachRouter

Reach Router 也提供了 Router 與 Link 組件,和 React Router 不同,它將直接將對應的組件寫在 Router 組件下,而不是,這么做無疑大大簡化了邏輯。

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 的參數接收方法就好像是直接給這個組件傳遞了參數的 Props 一樣,比 React Router 方便很多。

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

Reach Router 渲染有一個策略,一個路由下只會渲染一個最符合條件的路由。

嵌套路由

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>
)

以上就是關于“React router基礎使用方法有哪些”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

文水县| 林周县| 车致| 洪泽县| 将乐县| 桐庐县| 崇礼县| 广河县| 乳山市| 正定县| 施甸县| 合肥市| 建水县| 神池县| 宜州市| 乐都县| 姜堰市| 济阳县| 怀化市| 工布江达县| 抚州市| 桂平市| 白银市| 抚远县| 乾安县| 寿阳县| 临泉县| 黄浦区| 固镇县| 牙克石市| 台南市| 临泽县| 建水县| 曲阜市| 大连市| 万盛区| 绥中县| 高陵县| 武乡县| 惠东县| 彩票|