这篇文章主要介绍“Vue路由重复点击报错如何解决”,在日常操作中,相信很多人在Vue路由重复点击报错如何解决问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Vue路由重复点击报错如何解决”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
Uncaught (in promise) NavigationDuplicated: Avoided redundant navigation to current location:XXX
虽然不影响运行结果,但最好还是处理一下。
局部处理是指对单个路由进行处理,其他的路由依旧报错。
在路由跳转的push语句中添加catch捕捉错误
所以原来的路由跳转改为以下代码:
toecharts(){ this.$router.push({ path:'/echarts' } ).catch(err => {}) //添加catch捕捉错误 }
全局处理是指对所有路由进行处理。
在main.js文件添加以下代码(代码直接复制就好,无需改动)
import Router from 'vue-router' const originalPush = Router.prototype.push Router.prototype.push = function push(location) { return originalPush.call(this, location).catch(err => err) }
报错信息
vue-router在3.0版本以上时,重复点菜单,控制台会报错,虽然不影响使用,但是最好处理下这个问题,不然也可能会影响调试其他问题。
vue-router在3.0版本以上时 ,回调形式改成了promise api,返回的是promise,如果没有捕获到错误,控制台始终会出现如上图的报错
node_module/vue-router/dist/vue-router.js 搜VueRouter.prototype.push
1.降低vue-router的版本
npm i vue-router@3.0 -S
2.在vue.use(Router)使用路由插件之前插入如下代码
//获取原型对象上的push函数 const originalPush = Router.prototype.push //修改原型对象中的push方法 Router.prototype.push = function push (location) { return originalPush.call(this, location).catch(err => err) }
3.捕获异常
// 捕获router.push异常 this.$router.push(route).catch(err => { console.log('输出报错',err)
4.补齐router第三个参数
// 补齐router.push()的第三个参数 this.$router.push(route, () => {}, (e) => { console.log('输出报错',e) })
到此,关于“Vue路由重复点击报错如何解决”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。