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

路由react-router-dom的基本使用教程

 更新時(shí)間:2023年02月02日 09:18:13   作者:滴水微瀾  
在React中,路由是一套映射規(guī)則,是URL路徑與組件的對(duì)應(yīng)關(guān)系。使用React路由,就是配置路徑和組件的對(duì)應(yīng)關(guān)系,這篇文章主要介紹了路由react-router-dom的使用,需要的朋友可以參考下

react-router-dom路由簡(jiǎn)介

現(xiàn)代的前端頁(yè)面大多是SPA(單頁(yè)面應(yīng)用程序), 也就是只有一個(gè)HTML頁(yè)面的程序,這樣用戶體驗(yàn)好,服務(wù)器壓力小,所以更受歡迎。路由是使用單頁(yè)面來管理原來多頁(yè)面的功能。路由的功能:從一個(gè)頁(yè)面,跳轉(zhuǎn)到另一個(gè)頁(yè)面。在React中,路由是一套映射規(guī)則,是URL路徑與組件的對(duì)應(yīng)關(guān)系。使用React路由,就是配置路徑和組件的對(duì)應(yīng)關(guān)系。React的一切都是組件,可以像思考組件一樣看待路由。

react-router-dom路由的基本使用

//1.安裝庫(kù)
npm i react-router-dom
//2.<Router>在根組件上包裹所有內(nèi)容組件
<Router>
//3.<Link點(diǎn)擊跳轉(zhuǎn)到目標(biāo)組件頁(yè)面
<Link to="/first">頁(yè)面一</Link>定義一個(gè)跳轉(zhuǎn)鏈接
//4.<Routes>包裹具體的路由定義
 <Routes>
  <Route path="/first" element={<First/>}/>
</Routes>
import React from "react";
import {BrowserRouter as Router, Route, Link, Routes} from "react-router-dom"
 
// import {HashRouter as Router, Route, Link, Routes} from "react-router-dom"
 
const First = () => {
  return (
      <p>這是First組件頁(yè)面</p>
  )
}
 
class RouterApp extends React.Component{
  render() {
    return (
        <Router>
          <div>
            路由主頁(yè)
            <Link to="/first">頁(yè)面一</Link>
            <Routes>
              <Route path="/first" element={<First/>}/>
            </Routes>
          </div>
        </Router>
    );
  }
}

設(shè)置默認(rèn)路由

一進(jìn)入這個(gè)頁(yè)面,就展示這個(gè)組件,通過將路徑設(shè)置成"/"來實(shí)現(xiàn)。

<Route path={"/"} element={<Login/>}/>

class RouterApp extends React.Component{
  render() {
    return (
        <Router>
          <div>
            路由主頁(yè)
            <Link to="/first">頁(yè)面一</Link>
            <Routes>
              <Route path="/first" element={<First/>}/>
              <Route path={"/"} element={<Login/>}/>
            </Routes>
          </div>
        </Router>
    );
  }
}

常用組件介紹

Router組件

包裹整個(gè)應(yīng)用,在根組件上添加,一個(gè)React應(yīng)用只添加一次。Router有兩種,HashRouter和BrowserRouterHashRouter使用URL的hash值實(shí)現(xiàn) (http://localhost:3000/#/first)BrowserRouter使用H5的history API實(shí)現(xiàn) (http://localhost:3000/first)HashRouter和BrowserRouter是無縫切換的

import {BrowserRouter as Router, Route, Link, Routes} from "react-router-dom"
 
// import {HashRouter as Router, Route, Link, Routes} from "react-router-dom"

Link組件在頁(yè)面中最終會(huì)轉(zhuǎn)換成a標(biāo)簽。to中設(shè)置的值是瀏覽器上面的路由地址

location.pathname
'/first'
<Link to="/first">頁(yè)面一</Link>

Route組件指定路由展示組件的相關(guān)信息path屬性:路由規(guī)則element屬性:展示的組件Route寫在哪,路由渲染出來的組件就展示在哪。

<Routes>
  <Route path="/first" element={<First/>}/>
</Routes>

路由的執(zhí)行過程

1.當(dāng)點(diǎn)擊頁(yè)面中的Link標(biāo)簽時(shí),修改瀏覽器地址中的url

2.React路由監(jiān)聽地址欄url的變化

3.React遍歷所有的Route組件,使用路由規(guī)則(path)與pathname進(jìn)行匹配

4.當(dāng)路由規(guī)則path能夠匹配地址欄中的pathname時(shí),就展示這個(gè)Route對(duì)應(yīng)組件的內(nèi)容。

import React from "react";
import {BrowserRouter as Router, Route, Link, Routes} from "react-router-dom"
 
// import {HashRouter as Router, Route, Link, Routes} from "react-router-dom"
 
 
const First = () => <p>這是First組件頁(yè)面</p>
const Home = () => <h2>這是home主頁(yè)</h2>
 
class RouterApp extends React.Component{
  render() {
    return (
        <Router>
          <div>
 
            <Routes>
              <Route path="/first" element={<First/>}/>
              <Route path={"/home"} element={<Home/>}/>
            </Routes>
            路由主頁(yè)
            <br/>
            <Link to="/first">頁(yè)面一</Link>
            <br/>
            <Link to={"/home"}>Home主頁(yè)</Link>
          </div>
        </Router>
    );
  }
}

編程式導(dǎo)航

編程式導(dǎo)航是使用js代碼的形式實(shí)現(xiàn)的導(dǎo)航。

class Login extends React.Component{
  handleClick = () => {
    //history是在Routes選擇route展示組件時(shí),自動(dòng)傳入的。 
    //this.props.history.push("/manager") 
       
    let history = useHistory()
    history.push("/manager")
  }
 
  render() {
    return (
        <div>
          登錄頁(yè)面
          <button onClick={this.handleClick}>點(diǎn)擊登錄</button>
        </div>
    );
  }
}
 
const Manager = (props) => {
  let history = useHistory()
 
  const handleClick = () => {
    history.go(-1)
  }
 
  return (
      <div>
        管理后臺(tái)
        <button onClick={handleClick}>返回到登錄頁(yè)面</button>
      </div>
  )
}

匹配模式

模糊匹配-默認(rèn)

React的路由匹配模式是模糊匹配的

匹配規(guī)則是:只要pathname以path開頭,那么這個(gè)path對(duì)應(yīng)的組件就會(huì)被匹配成功,就會(huì)展示出來。直白說,只要跳轉(zhuǎn)的路由頁(yè)面的路由比較長(zhǎng)/login/a/b, 那么這個(gè)對(duì)應(yīng)組件的父級(jí),祖父級(jí)組件都能匹配到,并展示出來。如:/, /login, /login/a, /login/a/b。子級(jí)組件展示了,它的上級(jí)組件直到根組件都會(huì)展示出來。好像新版本v6這個(gè)匹配規(guī)則無效了

精確匹配只有當(dāng)pathname和path完全一樣時(shí),才會(huì)展示。在Route標(biāo)簽中加exact進(jìn)行修飾

<Route exact path={"/"} element={<Login/>}/>

版本變遷useHistory使用方式變化:react-router-dom v4 可以使withRouter (函數(shù)組件里可以用這個(gè)方法), class組件里可以直接this.props.history.pushreact-router-dom v5 是使用 useHistoryreact-router-domv6開始useNavigate取代了原先版本中的useHistory方法使用對(duì)比

useHistory用法
import { useHistory } from "react-router-dom";  //引入
 
 //使用:
// history.push({path:"/home"}); 也可以是對(duì)象 還可以傳值 params,state,search 都能傳 。
 const history = useHistory();
 history.push("/home");
 
useNavigate用法
import { useNavigate } from "react-router-dom";
const navigate = useNavigate();
navigate.push("/home");

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

相關(guān)文章

  • 基于React實(shí)現(xiàn)無限滾動(dòng)表格

    基于React實(shí)現(xiàn)無限滾動(dòng)表格

    以文本為例,為了實(shí)現(xiàn)無限循環(huán)的視覺效果,我們需要準(zhǔn)備兩段相同的文本,并讓第二段文本的頭部銜接在第一段文本的尾部,同時(shí),為兩段文本設(shè)置相同的滾動(dòng)動(dòng)畫,本文給大家介紹了基于React實(shí)現(xiàn)無限滾動(dòng)表格,需要的朋友可以參考下
    2023-11-11
  • React不使用requestIdleCallback實(shí)現(xiàn)調(diào)度原理解析

    React不使用requestIdleCallback實(shí)現(xiàn)調(diào)度原理解析

    這篇文章主要為大家介紹了React不使用requestIdleCallback實(shí)現(xiàn)調(diào)度原理解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • React中實(shí)現(xiàn)組件通信的幾種方式小結(jié)

    React中實(shí)現(xiàn)組件通信的幾種方式小結(jié)

    在構(gòu)建復(fù)雜的React應(yīng)用時(shí),組件之間的通信是至關(guān)重要的,從簡(jiǎn)單的父子組件通信到跨組件狀態(tài)同步,不同組件之間的通信方式多種多樣,下面我們認(rèn)識(shí)react組件通信的幾種方式,需要的朋友可以參考下
    2024-04-04
  • React中useTransition鉤子函數(shù)的使用詳解

    React中useTransition鉤子函數(shù)的使用詳解

    React?18的推出標(biāo)志著React并發(fā)特性的正式到來,其中useTransition鉤子函數(shù)是一個(gè)重要的新增功能,下面我們就來學(xué)習(xí)一下useTransition鉤子函數(shù)的具體使用吧
    2024-02-02
  • 一文帶你搞懂React的函數(shù)組件

    一文帶你搞懂React的函數(shù)組件

    React中函數(shù)式組件的基本意義是,組件實(shí)際上是一個(gè)函數(shù),不是類,下面就來給大家介紹一下關(guān)于React中函數(shù)組件的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-06-06
  • 淺談react?16.8版本新特性以及對(duì)react開發(fā)的影響

    淺談react?16.8版本新特性以及對(duì)react開發(fā)的影響

    本文主要介紹了react?16.8版本新特性以及對(duì)react開發(fā)的影響,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • react嵌套路由實(shí)現(xiàn)TabBar的實(shí)現(xiàn)

    react嵌套路由實(shí)現(xiàn)TabBar的實(shí)現(xiàn)

    本文主要介紹了react嵌套路由實(shí)現(xiàn)TabBar的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • react實(shí)現(xiàn)導(dǎo)航欄二級(jí)聯(lián)動(dòng)

    react實(shí)現(xiàn)導(dǎo)航欄二級(jí)聯(lián)動(dòng)

    這篇文章主要為大家詳細(xì)介紹了react實(shí)現(xiàn)導(dǎo)航欄二級(jí)聯(lián)動(dòng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • React實(shí)現(xiàn)全選功能

    React實(shí)現(xiàn)全選功能

    這篇文章主要為大家詳細(xì)介紹了React實(shí)現(xiàn)全選功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-08-08
  • react+antd+upload結(jié)合使用示例

    react+antd+upload結(jié)合使用示例

    這篇文章主要為大家介紹了react+antd+upload結(jié)合使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05

最新評(píng)論