KuangS_ 2024-01-10 15:38 采纳率: 0%
浏览 0

this.$router.push可以生效的vue-router版本


methods:{
    toUser(){
      console.log('to_user')
      this.$router.push({ path: '/Home' });
      
    },

vue2中this.$router.push不生效,而换成this.$router.replace可以正常起作用

  • 写回答

2条回答 默认 最新

  • 红薯不甜 全栈领域新星创作者 2024-01-10 17:43
    关注

    在 Vue.js 中,this.$router.push 和 this.$router.replace 这两个方法主要的区别是是否会向 history 栈中添加新的记录。使用 this.$router.push 会添加一个新的 history 记录,而使用 this.$router.replace 则会替换掉当前的 history 记录。

    如果你在 Vue.js 2 中遇到了 this.$router.push 不生效但 this.$router.replace 可以正常起作用的问题,那么可能的原因有:

    1. 你可能已经在当前的路由地址,this.$router.push 正在尝试导航到的地址也是当前地址。由于路由没有发生改变,因此看起来 this.$router.push 没有生效。而 this.$router.replace 会替换当前的 history 记录,因此即使目标地址和当前地址一样,你也可以看到页面发生了刷新。

    2. 可能存在导航守卫,例如 beforeRouteEnter、beforeRouteUpdate 或 beforeRouteLeave,并且在其中某个阶段调用了 next(false),会导致导航被阻止。这可能是看起来 this.$router.push 没有工作的原因。

    3. VueRouter 本身的错误,你可以尝试升级 VueRouter 到最新版本,或者检查是否有任何 VueRouter 的已知错误。

    评论

报告相同问题?

问题事件

  • 创建了问题 1月10日

悬赏问题

  • ¥15 校内二手商品转让网站
  • ¥20 高德地图聚合图层MarkerCluster聚合多个点,但是ClusterData只有其中部分数据,原因应该是有经纬度重合的地方点,现在我想让ClusterData显示所有点的信息,如何实现?
  • ¥100 求Web版SPC控制图程序包调式
  • ¥20 指导如何跑通以下两个Github代码
  • ¥15 大家知道这个后备文件怎么删吗,为啥这些文件我只看到一份,没有后备呀
  • ¥15 C++为什么这个代码没报错运行不出来啊
  • ¥15 一道ban了很多东西的pyjail题
  • ¥15 关于#r语言#的问题:如何将生成的四幅图排在一起,且对变量的赋值进行更改,让组合的图漂亮、美观@(相关搜索:森林图)
  • ¥15 C++识别堆叠物体异常
  • ¥15 微软硬件驱动认证账号申请