一、问题背景

官网首页Herder鼠标悬浮有很多二级页面,点击二级页面会进行跳转,当我已经在一个二级页面时,点击顶部导航中当前二级页面的其中一个状态(其实可以用三级页面,但是因为内容不多,我将一些内容写在了同一个二级页面通过一个参数来区分当前显示的什么内容)- 页面路由不变,params改变,这个时候因为router页面栈中已经存在了一个当前页面,此时再push一个当前路由就会报错

vue-router.esm.js?8c4f:2065 Uncaught (in promise) NavigationDuplicated: Avoided redundant navigation to current location:*******

二、解决办法

router.js中增加下面代码:

const VueRouterPush = VueRouter.prototype.push
VueRouter.prototype.push = function push (to) {
  return VueRouterPush.call(this, to).catch(err => err)
}

齐活! 亲测有效!

Logo

前往低代码交流专区

更多推荐