React路由規(guī)則定義與聲明式導航及編程式導航分別介紹
1. 路由使用
安裝路由模塊:
路由模塊不是react自帶模塊,需要安裝第3方模塊:
yarn add react-router-dom@5
路由相關(guān)組件:
路由模式組件:包裹整個應用,一個React應用只需要使用一次
- HashRouter: 使用URL的哈希值實現(xiàn) (
localhost:3000/#/first
) - BrowserRouter:使用H5的history API實現(xiàn)(
localhost3000/first
)
導航組件:用于指定導航鏈接, 最終Link會編譯成a標簽
- Link: 不會有激活樣式
- NavLink:如果地址欄中的地址和 to 屬性相匹配,則會有激活樣式
路由規(guī)則定義組件:指定路由規(guī)則和對應匹配成功后要渲染的組件
Route:
- path屬性:路由路徑,在地址欄中訪問的地址
- component屬性:和規(guī)則匹配成功后渲染的組件 /render/children
各組件關(guān)系示意圖:
定義路由的模式:
為了日后讓當前項目中所有的組件都受到路由控制,定義在index.js中,在最頂層定義路由模式。src/index.js
import React from 'react'; import ReactDOM from 'react-dom'; import App from './App'; import './utils/init' // 引入路由相關(guān)組件 路由模式組件,告訴當前項目,我們要使用的路由模式 // HashRouter hash路由模式 // BrowserRouter history路由模式,上線時,需要對nginx進行配置 import { BrowserRouter as Router, HashRouter } from 'react-router-dom' ReactDOM.render( <Router> <App /> </Router>, document.getElementById('root') )
定義路由規(guī)則:
路由規(guī)則組件可以定義在src/index.js
文件中,也可以定義在App組件中。
本次定義在src/App.js
文件中。
import React, { Component } from 'react' // Route 定義路由規(guī)則 路由地址和匹配成功后要渲染的組件 import { Route } from 'react-router-dom' // 匹配成功后渲染的組件 import Home from './views/Home' import About from './views/About' class App extends Component { render() { return ( <div> <h3>App組件</h3> <hr /> {/* 定義路由規(guī)則 */} <Route path="/home" component={Home} /> <Route path="/about" component={About} /> </div> ) } } export default App
2. 聲明式導航
描述:
使用 Link 或 NavLink 組件完成聲明式導航的定義、
Link/NavLink 區(qū)別:
- Link組件不會根據(jù)路由的變化而添加或修改編譯后html標簽中的屬性
- NavLink會根據(jù)路由的變化而自動修改編譯后html標簽中的屬性
如果當前的路由規(guī)則和 Navlink 中的 To 所寫的規(guī)則一致則添加 class 樣式,
默認名稱為 active,可以通過 activeClassName 來修改匹配成功后樣式名稱。
使用:
import React, { Component } from 'react' // Route 定義路由規(guī)則 路由地址和匹配成功后要渲染的組件 // Link 導航組件,它編譯生成后的html標簽只能是 a // NavLink 導航組件,它編譯生成后的html標簽只能是 a,但是它有激活樣式(地址欄中的地址和to屬性匹配,就有內(nèi)置樣式名) import { Route, Link, NavLink } from 'react-router-dom' // 匹配成功后渲染的組件 import Home from './views/Home' import About from './views/About' class App extends Component { render() { return ( <div> <h3>App組件</h3> <div> {/* <Link to="/home">Home</Link> --- <Link to="/about">About</Link> */} {/* NavLink 匹配規(guī)則,默認為模糊匹配 嚴格匹配:exact 修改激活樣式名稱:activeClassName='aaa' */} {/* <NavLink exact activeClassName='aa' to="/">Home</NavLink> --- */} <NavLink exact to="/">Home</NavLink>--- <NavLink to="/about">About</NavLink> </div> <hr /> {/* 定義路由規(guī)則 */} {/* 匹配默認為模糊匹配,而且它還會一直匹配到?jīng)]有規(guī)則組件為止 嚴格匹配:exact */} <Route exact path="/" component={Home} /> <Route path="/about" component={About} /> </div> ) } } export default App
利用 Switch 嚴格匹配路由:
import React, { Component } from 'react' // Route 定義路由規(guī)則 路由地址和匹配成功后要渲染的組件 // Link 導航組件,它編譯生成后的html標簽只能是 a // NavLink 導航組件,它編譯生成后的html標簽只能是 a,但是它有激活樣式(地址欄中的地址和to屬性匹配,就有內(nèi)置樣式名) // Switch 多個路由規(guī)則只匹配一個 import { Route, Link, NavLink, Switch } from 'react-router-dom' // 匹配成功后渲染的組件 import Home from './views/Home' import About from './views/About' class App extends Component { render() { return ( <div> <h3>App組件</h3> <div> {/* <Link to="/home">Home</Link> --- <Link to="/about">About</Link> */} {/* NavLink 匹配規(guī)則,默認為模糊匹配 嚴格匹配:exact 修改激活樣式名稱:activeClassName='aaa' */} {/* <NavLink exact activeClassName='aa' to="/">Home</NavLink> --- */} <NavLink exact to="/">Home</NavLink>--- <NavLink to="/about">About</NavLink> </div> <hr /> {/* 定義路由規(guī)則 */} {/* 匹配默認為模糊匹配,而且它還會一直匹配到?jīng)]有規(guī)則組件為止 嚴格匹配:exact */} <Switch> <Route path="/about" component={About} /> {/* 注意這個規(guī)則要放在最后,否則所有路由都會走 home 頁面 */} <Route path="/" component={Home} /> </Switch> </div> ) } } export default App
重定向和404:
import React, { Component } from 'react' // Route 定義路由規(guī)則 路由地址和匹配成功后要渲染的組件 // Link 導航組件,它編譯生成后的html標簽只能是 a // NavLink 導航組件,它編譯生成后的html標簽只能是 a,但是它有激活樣式(地址欄中的地址和to屬性匹配,就有內(nèi)置樣式名) // Switch 多個路由規(guī)則只匹配一個 // Redirect 重定向 使用它,一定要用到Switch,否則有死循環(huán)的問題 import { Route, Link, NavLink, Switch, Redirect } from 'react-router-dom' // 匹配成功后渲染的組件 import Home from './views/Home' import About from './views/About' // import Detail from './views/Detail' import Notfound from './views/Notfound' class App extends Component { render() { return ( <div> <h3>App組件</h3> <div> <NavLink exact to="/">Home</NavLink>--- <NavLink to="/about">About</NavLink> </div> <hr /> <Switch> {/* 如果你想用對于匹配渲染成功后的組件使用編程式導航,你默認情況下,你只能在規(guī)則匹配成功后的組件本身中使用,它的子組件都不行 */} <Route path="/home" component={Home} /> <Route path="/about" component={About} /> {/* 重定向 */} <Redirect exact from="/" to="/home" /> {/* 以上的路由沒有一個匹配成功的,則用404頁面 path屬性不要寫 */} <Route component={Notfound} /> </Switch> </div> ) } } export default App
3. 編程式導航
App.jsx:
import React, { Component } from 'react' import { Route, Link, NavLink, Switch, Redirect } from 'react-router-dom' // 匹配成功后渲染的組件 import Home from './views/Home' import About from './views/About' // import Detail from './views/Detail' import Notfound from './views/Notfound' class App extends Component { render() { return ( <div> <h3>App組件</h3> <div> <NavLink exact to="/">Home</NavLink>--- <NavLink to="/about">About</NavLink> </div> <hr /> <Switch> {/* 如果你想用對于匹配渲染成功后的組件使用編程式導航,你默認情況下,你只能在規(guī)則匹配成功后的組件本身中使用,它的子組件都不行 */} <Route path="/home" component={Home} /> <Route path="/about" component={About} /> {/* 重定向 */} <Redirect exact from="/" to="/home" /> {/* 以上的路由沒有一個匹配成功的,則用404頁面 path屬性不要寫 */} <Route component={Notfound} /> </Switch> </div> ) } } export default App
home組件:
import React, { Component } from 'react' import Btn from './Btn' class Home extends Component { jumpUrl = () => { // 寫法1 // this.props.history.push('/about') // 寫法2 this.props.history.push({ pathname: '/about' }) } render() { return ( <div> <h3>首頁展示</h3> <button onClick={this.jumpUrl}>home組件中回關(guān)于</button> <Btn {...this.props} /> </div> ) } } export default Home
btn組件:
import React, { Component } from 'react' class Btn extends Component { jumpUrl = () => { this.props.history.push('/about') } render() { return <button onClick={this.jumpUrl}>在btn組件中回關(guān)于</button> } } export default Btn
注意:
- 如果你想用對于匹配渲染成功后的組件使用編程式導航,默認情況下,你只能在規(guī)則匹配成功后的組件本身中使用,它的子組件都不行
- 直接匹配的路由的子組件要想使用編程式導航,則需要給他傳遞 props
到此這篇關(guān)于React路由規(guī)則定義與聲明式導航及編程式導航分別介紹的文章就介紹到這了,更多相關(guān)React路由規(guī)則內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
React組件實例三大屬性state props refs使用詳解
這篇文章主要為大家介紹了React組件實例三大屬性state props refs使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-09-09詳解React-Native全球化多語言切換工具庫react-native-i18n
這篇文章主要介紹了詳解React-Native全球化語言切換工具庫react-native-i18n,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-11-11React中useEffect原理的代碼簡單實現(xiàn)詳解
React的useEffect鉤子是React函數(shù)組件中處理副作用,本文將通過一個簡單的例子解釋如何用代碼實現(xiàn)useEffect的基本原理,感興趣的小伙伴可以了解下2023-12-12