React

关注公众号 jb51net

关闭
首页 > 网络编程 > JavaScript > javascript类库 > React > react中history(push,go,replace)切换路由方法区别

react中history(push,go,replace)切换路由方法的区别及说明

作者:我是一个粉刷匠呀

这篇文章主要介绍了react中history(push,go,replace)切换路由方法的区别及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

react中history(push,go,replace)切换路由方法区别

history.push方法更改当前路由,会向当前路由栈里面添加一条新的记录,跳转后点击回退可回退到当前页面

history.replace方法更改当前路由,不会向当前路由栈里面添加一条新的记录,跳转后点击回退不可回退到当前页面,与他的名字一样,是直接替换当前路由

history.go方法与window.history.go()类似,参数为整数,表示向前或向后跳转

react中的history出现的问题

在学习react的时候,创建了一个react+ts的项目框架。

遇到一个问题,使用history无法进行页面跳转,即使跳转也无法渲染页面。

创建项目

使用以下语法创建了一个简单的项目框架

create-react-app xxx --scripts-version=react-scripts-ts

history的用法

在react-router很大的程度上依赖history的功能。

history分为两类:

现象

使用了Router这个路由器,传入history属性,但是在使用createHashHistory 和 createBrowserHistory创建的history时

出现了问题:

原因

react-router-dom是基于react-router进行开发的。

在npm中的history库中找到:

推测是版本的问题,于是将版本降低,能正常跳转。

解决方法

降低history版本,就可以解决无法渲染问题。

npm install history@4.1.0 -D

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文