路由react-router-dom的基本使用教程
react-router-dom路由簡介
現(xiàn)代的前端頁面大多是SPA(單頁面應(yīng)用程序), 也就是只有一個HTML頁面的程序,這樣用戶體驗好,服務(wù)器壓力小,所以更受歡迎。路由是使用單頁面來管理原來多頁面的功能。路由的功能:從一個頁面,跳轉(zhuǎn)到另一個頁面。在React中,路由是一套映射規(guī)則,是URL路徑與組件的對應(yīng)關(guān)系。使用React路由,就是配置路徑和組件的對應(yīng)關(guān)系。React的一切都是組件,可以像思考組件一樣看待路由。
react-router-dom路由的基本使用
//1.安裝庫 npm i react-router-dom //2.<Router>在根組件上包裹所有內(nèi)容組件 <Router> //3.<Link點擊跳轉(zhuǎn)到目標(biāo)組件頁面 <Link to="/first">頁面一</Link>定義一個跳轉(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組件頁面</p> ) } class RouterApp extends React.Component{ render() { return ( <Router> <div> 路由主頁 <Link to="/first">頁面一</Link> <Routes> <Route path="/first" element={<First/>}/> </Routes> </div> </Router> ); } }
設(shè)置默認(rèn)路由
一進(jìn)入這個頁面,就展示這個組件,通過將路徑設(shè)置成"/"來實現(xiàn)。
<Route path={"/"} element={<Login/>}/>
class RouterApp extends React.Component{ render() { return ( <Router> <div> 路由主頁 <Link to="/first">頁面一</Link> <Routes> <Route path="/first" element={<First/>}/> <Route path={"/"} element={<Login/>}/> </Routes> </div> </Router> ); } }
常用組件介紹
Router組件
包裹整個應(yīng)用,在根組件上添加,一個React應(yīng)用只添加一次。Router有兩種,HashRouter和BrowserRouterHashRouter使用URL的hash值實現(xiàn) (http://localhost:3000/#/first)BrowserRouter使用H5的history API實現(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組件在頁面中最終會轉(zhuǎn)換成a標(biāo)簽。to中設(shè)置的值是瀏覽器上面的路由地址
location.pathname '/first'
<Link to="/first">頁面一</Link>
Route組件指定路由展示組件的相關(guān)信息path屬性:路由規(guī)則element屬性:展示的組件Route寫在哪,路由渲染出來的組件就展示在哪。
<Routes> <Route path="/first" element={<First/>}/> </Routes>
路由的執(zhí)行過程
1.當(dāng)點擊頁面中的Link標(biāo)簽時,修改瀏覽器地址中的url
2.React路由監(jiān)聽地址欄url的變化
3.React遍歷所有的Route組件,使用路由規(guī)則(path)與pathname進(jìn)行匹配
4.當(dāng)路由規(guī)則path能夠匹配地址欄中的pathname時,就展示這個Route對應(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組件頁面</p> const Home = () => <h2>這是home主頁</h2> class RouterApp extends React.Component{ render() { return ( <Router> <div> <Routes> <Route path="/first" element={<First/>}/> <Route path={"/home"} element={<Home/>}/> </Routes> 路由主頁 <br/> <Link to="/first">頁面一</Link> <br/> <Link to={"/home"}>Home主頁</Link> </div> </Router> ); } }
編程式導(dǎo)航
編程式導(dǎo)航是使用js代碼的形式實現(xiàn)的導(dǎo)航。
class Login extends React.Component{ handleClick = () => { //history是在Routes選擇route展示組件時,自動傳入的。 //this.props.history.push("/manager") let history = useHistory() history.push("/manager") } render() { return ( <div> 登錄頁面 <button onClick={this.handleClick}>點擊登錄</button> </div> ); } } const Manager = (props) => { let history = useHistory() const handleClick = () => { history.go(-1) } return ( <div> 管理后臺 <button onClick={handleClick}>返回到登錄頁面</button> </div> ) }
匹配模式
模糊匹配-默認(rèn)
React的路由匹配模式是模糊匹配的
匹配規(guī)則是:只要pathname以path開頭,那么這個path對應(yīng)的組件就會被匹配成功,就會展示出來。直白說,只要跳轉(zhuǎn)的路由頁面的路由比較長/login/a/b, 那么這個對應(yīng)組件的父級,祖父級組件都能匹配到,并展示出來。如:/, /login, /login/a, /login/a/b。子級組件展示了,它的上級組件直到根組件都會展示出來。好像新版本v6這個匹配規(guī)則無效了
精確匹配只有當(dāng)pathname和path完全一樣時,才會展示。在Route標(biāo)簽中加exact進(jìn)行修飾
<Route exact path={"/"} element={<Login/>}/>
版本變遷useHistory使用方式變化:react-router-dom v4 可以使withRouter (函數(shù)組件里可以用這個方法), class組件里可以直接this.props.history.pushreact-router-dom v5 是使用 useHistoryreact-router-domv6開始useNavigate取代了原先版本中的useHistory方法使用對比
useHistory用法 import { useHistory } from "react-router-dom"; //引入 //使用: // history.push({path:"/home"}); 也可以是對象 還可以傳值 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)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
React不使用requestIdleCallback實現(xiàn)調(diào)度原理解析
這篇文章主要為大家介紹了React不使用requestIdleCallback實現(xiàn)調(diào)度原理解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11React中實現(xiàn)組件通信的幾種方式小結(jié)
在構(gòu)建復(fù)雜的React應(yīng)用時,組件之間的通信是至關(guān)重要的,從簡單的父子組件通信到跨組件狀態(tài)同步,不同組件之間的通信方式多種多樣,下面我們認(rèn)識react組件通信的幾種方式,需要的朋友可以參考下2024-04-04React中useTransition鉤子函數(shù)的使用詳解
React?18的推出標(biāo)志著React并發(fā)特性的正式到來,其中useTransition鉤子函數(shù)是一個重要的新增功能,下面我們就來學(xué)習(xí)一下useTransition鉤子函數(shù)的具體使用吧2024-02-02淺談react?16.8版本新特性以及對react開發(fā)的影響
本文主要介紹了react?16.8版本新特性以及對react開發(fā)的影響,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-03-03react嵌套路由實現(xiàn)TabBar的實現(xiàn)
本文主要介紹了react嵌套路由實現(xiàn)TabBar的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08react實現(xiàn)導(dǎo)航欄二級聯(lián)動
這篇文章主要為大家詳細(xì)介紹了react實現(xiàn)導(dǎo)航欄二級聯(lián)動,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-03-03