這篇文章給大家介紹什么是react路由知識,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
簡單的說就是根據不同的地址,web服務器處理不同的業務以及邏輯。
以下代碼全部運行在react腳手架中
// 組件更新機制:
// 只要父組件重新渲染了, 所有的組件子樹, 也會更新
// 性能優化
// 1. 減輕state
// 2. 避免不必要的重新渲染 (性能優化)
// shouldComponentUpdate(nextProps, nextState) { .... }
// 鉤子函數返回一個布爾值, true要更新 false不更新
// 手動實現固然是可以的, 但是太麻煩
// 3. 實際官網提供了一個純組件, 內部已經幫你實現好了 shouldComponentUpdate 的邏輯
// 會幫你進行props 和 state的比對, 決定是否要更新
// 普通組件: class App extends React.Component
// 純組件: class App extends React.PureComponent 會比普通組件, 多一個比對數據的過程
// 比如: 一個組件要渲染出來, 性能損耗很大, 此時可以考慮純組件, 避免掉一些無意義的更新
// 不是所有的場景, 都要用純組件, 正常應該都用普通組件
import React from 'react'
import ReactDOM from 'react-dom'
class App extends React.PureComponent {
state = {
nameList: ['帥鵬', '呂布', '張飛'],
currentName: '',
}
render() {
console.log('App-render')
return (
<div>
<h2>我是App組件</h2>
<h4>結果: {this.state.currentName}</h4>
<button onClick={this.handleClick.bind(this)}>點名</button>
</div>
)
}
handleClick() {
const randomIndex = parseInt(Math.random() * this.state.nameList.length)
const currentName = this.state.nameList[randomIndex]
this.setState({
currentName,
})
console.log(currentName)
}
// 需求: 如果state的值, 沒有發生變化, 其實也不需要更新, 避免一些不必要的更新
// shouldComponentUpdate(nextProps, nextState) {
// if (this.state.currentName === nextState.currentName) {
// return false
// } else {
// return true
// }
// }
}
ReactDOM.render(<App></App>, document.getElementById('root'))// 4. 純組件的使用注意點 (如果純組件有子組件, 子組件也要是純組件 (一家子都純))
// (1) 純組件內部進行的是淺層對比, 值類型沒有問題, 復雜類型只比較地址
// (2) 使用純組件, 更新數據時, 簡單類型沒有問題, 復雜類型更新了, 是需要修改地址的(新對象 / 新數組)
import React from 'react'
import ReactDOM from 'react-dom'
class App extends React.PureComponent {
state = {
nameList: ['帥鵬', '呂布', '張飛'],
currentName: '',
obj: {
name: 'zs',
age: 18,
},
}
render() {
console.log('App-render')
return (
<div>
<h2>我是App組件</h2>
<p>name: {this.state.obj.name}</p>
<p>{this.state.nameList}</p>
<button onClick={this.handleClick.bind(this)}>改值</button>
</div>
)
}
handleClick() {
// 要更新對象, 要準備一個新對象
// const obj = { ...this.state.obj }
// obj.name = 'ls'
// this.setState({
// obj: obj,
// })
// 要更新數組, 要準備一個新數組
// this.setState({
// nameList: [...this.state.nameList, '王五'],
// })
const arr = [...this.state.nameList]
arr.push('王五')
this.setState({
nameList: arr,
})
}
}
ReactDOM.render(<App></App>, document.getElementById('root'))import React from 'react'
import ReactDOM from 'react-dom'
import { HashRouter, Link, Route } from 'react-router-dom'
// 路由的使用:
// 1. 下載 yarn add react-router-dom
// 2. react-router-dom是一個包, 包含了很多的組件
// 3. HashRouter組件, 是整個的路由對象, 一個項目就一個, 需要將整個項目的內容包裹
// 4. Link組件, 渲染成一個 a 鏈接, 可以用于路由跳轉, 通過 to 配置路徑
// 5. Route組件, 配置路由規則(哪個路徑匹配哪個組件), 也是路由出口!
// 每個Route互相之間是獨立的, 只要路徑匹配, 就可以展示配置的組件
// 定義了三個函數組件
const Home = () => <div>我是Home組件</div>
const Login = () => <div>我是Login組件</div>
const User = () => <div>我是User組件</div>
class App extends React.PureComponent {
render() {
return (
<div>
<h2>我是App組件</h2>
<ul>
<li>
<Link to="/home">首頁</Link>
</li>
<li>
<Link to="/login">登錄</Link>
</li>
<li>
<Link to="/user">用戶</Link>
</li>
</ul>
{/* 只要path路徑, 和地址欄的路徑匹配, 就會展示配置的組件 */}
<Route path="/home" component={Home}></Route>
<Route path="/login" component={Login}></Route>
<Route path="/user" component={User}></Route>
</div>
)
}
}
ReactDOM.render(
<HashRouter>
<App></App>
</HashRouter>,
document.getElementById('root')
)import React from 'react'
import ReactDOM from 'react-dom'
import { HashRouter as Router, Link, Route } from 'react-router-dom'
// Router組件, 有兩種 HashRouter, BrowserRouter
// 1. HashRouter底層實現基于: 地址欄的hash值, 基于錨點跳轉實現的
// 2. BrowserRouter底層實現基于: h6 的 history API, 地址欄沒有 #
// (如果要用開發時, 沒有問題, 但是上線了, 是需要后臺配置的)
// 定義了三個函數組件
const Home = () => <div>我是Home組件</div>
const Login = () => <div>我是Login組件</div>
const User = () => <div>我是User組件</div>
class App extends React.PureComponent {
render() {
return (
<div>
<h2>我是App組件</h2>
<ul>
<li>
<Link to="/home">首頁</Link>
</li>
<li>
<Link to="/login">登錄</Link>
</li>
<li>
<Link to="/user">用戶</Link>
</li>
</ul>
{/* 只要path路徑, 和地址欄的路徑匹配, 就會展示配置的組件 */}
<Route path="/home" component={Home}></Route>
<Route path="/login" component={Login}></Route>
<Route path="/user" component={User}></Route>
</div>
)
}
}
ReactDOM.render(
<Router>
<App></App>
</Router>,
document.getElementById('root')
)import React from 'react'
import ReactDOM from 'react-dom'
import { HashRouter as Router, NavLink, Route } from 'react-router-dom'
import './index.css'
// Link組件 和 NavLink組件
// 1. Link組件, 渲染成a鏈接, 用于路由跳轉, 通過to配置路徑
// 默認的Link, 不會有高亮的類名標識
// 2. NavLink組件, 渲染成a鏈接, 用于路由跳轉, 通過to配置路徑
// (1) NavLink, 在路徑匹配時, 會有高亮的類名 active
// (2) 可以通過activeClassName, 配置高亮的類名
// (3) 可以通過activeStyle, 直接配置改標簽, 高亮的樣式
// (4) 進行的是模糊匹配 to="/home" 可以匹配 /home /home/aa
// 精確匹配, 需要配置 exact 屬性, to="/home", 只能匹配 /home, 只會在 /home 時高亮
// 定義了三個函數組件
const Home = () => <div>我是Home組件</div>
const Login = () => <div>我是Login組件</div>
const User = () => <div>我是User組件</div>
class App extends React.PureComponent {
render() {
return (
<div>
<h2>我是App組件</h2>
<ul>
<li>
<NavLink
exact
to="/"
activeStyle={{ color: 'red', fontSize: '30px' }}
>
首頁
</NavLink>
</li>
<li>
<NavLink to="/login" activeClassName="selected">
登錄
</NavLink>
</li>
<li>
<NavLink to="/user" activeClassName="selected">
用戶
</NavLink>
</li>
</ul>
{/* 只要path路徑, 和地址欄的路徑匹配, 就會展示配置的組件 */}
<Route path="/home" component={Home}></Route>
<Route path="/login" component={Login}></Route>
<Route path="/user" component={User}></Route>
</div>
)
}
}
ReactDOM.render(
<Router>
<App></App>
</Router>,
document.getElementById('root')
)/**index.css*/
.active {
color: red;
font-size: 30px;
}
.selected {
color: blue;
font-size: 30px;
}import React from 'react'
import ReactDOM from 'react-dom'
import { HashRouter as Router, NavLink, Route, Switch } from 'react-router-dom'
import './index.css'
// Route組件
// 作用: 可以配置路由規則, 也是路由的出口, 只要路徑匹配了, 那么配置的組件, 就會在這里展示
// <Route path="/login" component={Login}></Route>
// 1. 每個Route之間, 互相是獨立的 (包括配置多個相同路徑, 顯示不同組件, 也是可以的)
// 2. Route配置的路徑, 也是進行的模糊匹配, 可以通過 exact 進行精確匹配
// 3. 如果不配置路徑, 那么配置的組件, 默認都會展示
// 會配合Switch組件, 可以完成404頁面的配置
// Switch組件: 可以將多個Route組件包裹, 可以讓第一個匹配的Route組件展示, 后續的不管
// 定義了函數組件
const Home = () => <div>我是Home組件</div>
const Login = () => <div>我是Login組件</div>
const User = () => <div>我是User組件</div>
const Error = () => <div>我是404頁面, 您要訪問的頁面不存在!!!</div>
class App extends React.PureComponent {
render() {
return (
<div>
<h2>我是App組件</h2>
<ul>
<li>
<NavLink
exact
to="/"
activeStyle={{ color: 'red', fontSize: '30px' }}
>
首頁
</NavLink>
</li>
<li>
<NavLink to="/login" activeClassName="selected">
登錄
</NavLink>
</li>
<li>
<NavLink to="/user" activeClassName="selected">
用戶
</NavLink>
</li>
</ul>
{/* 只要path路徑, 和地址欄的路徑匹配, 就會展示配置的組件 */}
<Switch>
<Route path="/" component={Home} exact></Route>
<Route path="/login" component={Login}></Route>
<Route path="/user" component={User}></Route>
<Route component={Error}></Route>
</Switch>
</div>
)
}
}
ReactDOM.render(
<Router>
<App></App>
</Router>,
document.getElementById('root')
)嵌套路由
import React from 'react'
import ReactDOM from 'react-dom'
import {
HashRouter as Router,
NavLink,
Route,
Switch,
Redirect,
} from 'react-router-dom'
import './index.css'
// Redirect組件: 可以重定向, from從哪 to跳到哪
// react中, 配置嵌套路由, 非常的簡單, 你只需要在需要寫嵌套子路由的地方, 直接寫Route組件即可
// 前提條件, 你配置的嵌套子路由, 路徑一定要包含父路由的路徑
// 定義了函數組件
const Home = () => (
<div>
<h4>我是Home組件</h4>
</div>
)
const Login = () => (
<div>
<h4>我是Login組件</h4>
</div>
)
// ------------------------------------------------------------------------
// 需求: 用戶User組件內部, 還有個人信息, 我的收藏
const User = () => (
<div>
<h4>我是User組件</h4>
<Route path="/user" exact component={UserDefault}></Route>
<Route path="/user/info" component={Info}></Route>
<Route path="/user/star" component={Star}></Route>
</div>
)
const UserDefault = () => <div>我是默認的User內容</div>
const Info = () => <div>我是Info組件</div>
const Star = () => <div>我是Star組件</div>
// -------------------------------------------------------------------------
const Error = () => <div>我是404頁面, 您要訪問的頁面不存在!!!</div>
class App extends React.PureComponent {
render() {
return (
<div>
<h2>我是App組件</h2>
<ul>
<li>
<NavLink
exact
to="/"
activeStyle={{ color: 'red', fontSize: '30px' }}
>
首頁
</NavLink>
</li>
<li>
<NavLink to="/login" activeClassName="selected">
登錄
</NavLink>
</li>
<li>
<NavLink to="/user" activeClassName="selected">
用戶
</NavLink>
</li>
</ul>
{/* 只要path路徑, 和地址欄的路徑匹配, 就會展示配置的組件 */}
<Switch>
<Route path="/" component={Home} exact></Route>
<Redirect from="/home" to="/"></Redirect>
<Route path="/login" component={Login}></Route>
<Route path="/user" component={User}></Route>
<Route component={Error}></Route>
</Switch>
</div>
)
}
}
ReactDOM.render(
<Router>
<App></App>
</Router>,
document.getElementById('root')
)import React from 'react'
import ReactDOM from 'react-dom'
import { HashRouter as Router, Route, Link } from 'react-router-dom'
import './index.css'
// 如果想拿到動態路由的參數信息, 需要通過props獲取,
// Route會將路由相關信息, 相關方法, 都會通過 props 傳給你的組件
// const Product = (props) => <div>我是product組件</div>
class Product extends React.Component {
render() {
// this.props 參數
// (1) history 里面存放的是跳轉路由的方法
// (2) location 里面存放的是當前路由地址
// (3) match 里面存放的是動態路由參數
console.log(this.props)
console.log(this.props.match.params.id)
return (
<div>
<h4>我是product組件 - {this.props.match.params.id}</h4>
<button onClick={this.handleClick.bind(this)}>回首頁</button>
</div>
)
}
handleClick() {
// console.log(this.props.history)
// this.props.history.go(-1)
this.props.history.push('/home')
}
}
const Home = () => <div>我是首頁</div>
class App extends React.Component {
render() {
return (
<div>
<h2>我是App組件</h2>
<div>
<Link to="/home">首頁</Link>
<Link to="/product/1">商品1</Link>
<Link to="/product/2">商品2</Link>
<Link to="/product/3">商品3</Link>
<Link to="/product/4">商品4</Link>
</div>
<Route path="/product/:id" component={Product}></Route>
<Route path="/home" component={Home}></Route>
</div>
)
}
}
ReactDOM.render(
<Router>
<App></App>
</Router>,
document.getElementById('root')
)關于什么是react路由知識就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。