Router 解决 NavigationDuplicated 错误
vue-router.esm.js:2054 Uncaught (in promise) NavigationDuplicated: Avoided redundant navigation to current location: “/operation/permission?tabroles”这个错误 NavigationDuplicated: Avoided redundant navigation to current location 是 vue-router 的一个经典问题。原因分析Vue Router 3.x 版本中当调用 this.router.push或this.router.push 或 this.router.push或this.router.replace 跳转到当前路由时会抛出一个 NavigationDuplicated 错误。如果调用处没有 .catch() 处理就会报 Uncaught (in promise)。处理方式通过重写 Router.prototype.push 和 Router.prototype.replace捕获该特定错误并忽略它同时保留其他真实错误的抛出。位置将上述代码放在 export default new Router(…) 之前即可生效。代码const originalPush Router.prototype.push Router.prototype.push function push(location) { return originalPush.call(this, location).catch(err { if (err.name ! NavigationDuplicated) { throw err } }) } const originalReplace Router.prototype.replace Router.prototype.replace function replace(location) { return originalReplace.call(this, location).catch(err { if (err.name ! NavigationDuplicated) { throw err } }) }
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2522435.html
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!