上篇文章学习了 React路由组件传参的三种方式 本篇文章学习学习 编程式路由导航及相关知识点,感兴趣的小伙伴可以来个三连哦~
🌷路由的push与replace
push模式是栈的常规模式,可以回到上一级,会留下痕迹
replace模式是替换模式,会替换掉栈顶的路由,回不到上一级,不会留下痕迹(无痕模式),适用于登录后,不需要重新回到登录页。
开启方法:
<Link replace={true} to={{ pathname: '/home/message/detail', state: { id: msgObj.id, title: msgObj.title } }}>
{msgObj.title}
</Link>
🌷编程式路由导航
编程式路由导航:通过JS路由对象的方式来实现页面跳转(push、replace、go)
声明式路由导航:
<
<
<Link
>
>
>和
<
<
<NavLink
>
>
>实现路由的跳转
随着react-router ,可以使用Link 元素创建的原生处理反应路由器链接。
但是,我不想点击链接进行导航,我想通过点击按钮自动实现页面跳转。实现方法如下:
this.props.history.push(`/home/message/detail/${id}/${title}`)
this.props.history.push(`/home/message/detail?id=${id}&title=${title}`)
this.props.history.push(`/home/message/detail`, { id: id, title: title })
this.props.history.replace(`/home/message/detail/${id}/${title}`)
this.props.history.replace(`/home/message/detail?id=${id}&title=${title}`)
this.props.history.replace(`/home/message/detail`, { id: id, title: title })
this.props.history.goForward()
this.props.history.goBack()
this.props.history.go(-2)
🌸案例需求
点击push按钮实现页面跳转,会留下历史记录,可以回到上一级;点击replace按钮也可以实现页面跳转,但是不会留下历史记录,不可以回到上一级;点击回退按钮,返回上一个记录的路由;点击前进按钮,前进一个记录的路由。
效果:
Message->index.jsx:
import React, { Component } from 'react'
import { Link, Route } from 'react-router-dom'
import Detail from './Detail';
export default class Message extends Component {
state = {
messageArr: [
{ id: '01', title: '消息1' },
{ id: '02', title: '消息2' },
{ id: '03', title: '消息3' }
]
}
replaceShow = (id, title) => {
this.props.history.replace(`/home/message/detail`, { id: id, title: title })
}
pushShow = (id, title) => {
this.props.history.push(`/home/message/detail`, { id: id, title: title })
}
back = () => {
this.props.history.goBack()
}
forward = () => {
this.props.history.goForward()
}
go = () => {
this.props.history.go(-2)
}
render() {
const { messageArr } = this.state
return (
<div>
<ul>
{
messageArr.map((msgObj) => {
return (
<li key={msgObj.id}>
{}
{}
{}
{}
{}
<Link to={{ pathname: '/home/message/detail', state: { id: msgObj.id, title: msgObj.title } }}>
{msgObj.title}
</Link>
<button onClick={() => { this.pushShow(msgObj.id, msgObj.title) }}>
push查看
</button>
<button onClick={() => { this.replaceShow(msgObj.id, msgObj.title) }}>
replace查看
</button>
</li>
)
})
}
</ul>
<hr />
{}
{}
{}
{}
{}
{}
<Route path="/home/message/detail" component={Detail} />
<button onClick={this.back}>回退</button>
<button onClick={this.forward}>前进</button>
<button onClick={this.go}>go</button>
</div>
)
}
}
Detail->index.jsx:
import React, { Component } from 'react'
const DetailData = [
{ id: '01', content: '你好,中国' },
{ id: '02', content: '你好,程序员' },
{ id: '03', content: '你好,csdn' }
]
export default class Detail extends Component {
render() {
console.log(this.props)
const { id, title } = this.props.location.state || {}
const findResult = DetailData.find((detailObj) => {
return detailObj.id === id
}) || {}
return (
<ul>
<li>ID: {id}</li>
<li>TITLE: {title}</li>
<li>CONTENT: {findResult.content}</li>
</ul>
)
}
}
🌸总结
借助this.props.history对象上的API对操作路由跳转、前进、后退
this.props.history.push()
this.props.history.replace()
this.props.history.goBack()
this.props.history.goForward()
this.props.history.go()
🌷withRouter的使用
由于路由组件的props中是有history属性的,而一般组件(非路由组件)是没有history属性。所以在一般组件中,是不能使用history属性身上的API的(push/replace/goBack等)。但是,WithRouter函数 可以解决上述问题。
引入WithRouter:
import {withRouter} from 'react-router-dom'
WithRouter :是一个函数 ,接收一个一般组件 作为参数,返回一个新组件 ,在新组件里的props里会被注入路由对象 ,让一般组件具备路由组件所特有的API。
使用WithRouter:
class Header extends Component {
}
export default withRouter(Header)
import React, { Component } from 'react'
import { withRouter } from 'react-router-dom'
class Header extends Component {
back = () => {
this.props.history.goBack()
}
forward = () => {
this.props.history.goForward()
}
go = () => {
this.props.history.go(-2)
}
render() {
console.log(this.props)
return (
<div className="page-header">
<h2>React Router Demo</h2>
<button onClick={this.back}>回退</button>
<button onClick={this.forward}>前进</button>
<button onClick={this.go}>go</button>
</div>
)
}
}
export default withRouter(Header)
这样一般组件里也能使用路由组件所特有的API。
🌷BrowserRouter与HashRouter的区别
底层原理不一样:
(1).BrowserRouter使用的是H5的history API ,不兼容IE9及以下版本。
(2).HashRouter使用的是URL的哈希值 。
path表现形式不一样:
(1).BrowserRouter的路径中没有# ,例如:localhost:3000/demo/test
(2).HashRouter的路径包含# ,例如:localhost:3000/#/demo/test
刷新后对路由state参数的影响:
(1).BrowserRouter没有任何影响,因为state保存在history对象 中。
(2).HashRouter刷新后会导致路由state参数的丢失 。
备注:HashRouter可以用于解决一些路径错误相关的问题(多级路径刷新页面样式丢失的问题)。
今天的分享就到这里啦 ? 如果对你有帮助的话,还请👉🏻关注💖点赞🤞收藏?评论🔥哦 不定时回访哟🌹
|