返回顶部
首页 > 资讯 > 精选 >Vue路由重复点击报错如何解决
  • 101
分享到

Vue路由重复点击报错如何解决

2023-07-05 21:07:45 101人浏览 独家记忆
摘要

这篇文章主要介绍“Vue路由重复点击报错如何解决”,在日常操作中,相信很多人在Vue路由重复点击报错如何解决问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Vue路由重复点击报错如何解决”的疑惑有所帮助!接下来

这篇文章主要介绍“Vue路由重复点击报错如何解决”,在日常操作中,相信很多人在Vue路由重复点击报错如何解决问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Vue路由重复点击报错如何解决”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

vue路由重复点击时会出现报错

Uncaught (in promise) NavigationDuplicated: Avoided redundant navigation to current location:XXX

虽然不影响运行结果,但最好还是处理一下。

Vue路由重复点击报错如何解决

局部处理

局部处理是指对单个路由进行处理,其他的路由依旧报错。

在路由跳转的push语句中添加catch捕捉错误

所以原来的路由跳转改为以下代码:

toecharts(){            this.$router.push({                    path:'/echarts'                }            ).catch(err => {})//添加catch捕捉错误        }

全局处理

全局处理是指对所有路由进行处理。

在main.js文件添加以下代码(代码直接复制就好,无需改动)

import Router from 'vue-router'const originalPush = Router.prototype.pushRouter.prototype.push = function push(location) {return originalPush.call(this, location).catch(err => err)}

vue 重复点击菜单,路由重复报错解决

报错信息

vue-router在3.0版本以上时,重复点菜单,控制台会报错,虽然不影响使用,但是最好处理下这个问题,不然也可能会影响调试其他问题。

Vue路由重复点击报错如何解决

报错原因

vue-router在3.0版本以上时 ,回调形式改成了promise api,返回的是promise,如果没有捕获到错误,控制台始终会出现如上图的报错

node_module/vue-router/dist/vue-router.js 搜VueRouter.prototype.push

解决方法

降低vue-router的版本

npm i vue-router@3.0 -S

在vue.use(Router)使用路由插件之前插入如下代码

//获取原型对象上的push函数const originalPush = Router.prototype.push//修改原型对象中的push方法Router.prototype.push = function push (location) {  return originalPush.call(this, location).catch(err => err)}

捕获异常

// 捕获router.push异常this.$router.push(route).catch(err => {    console.log('输出报错',err)

补齐router第三个参数

// 补齐router.push()的第三个参数this.$router.push(route, () => {}, (e) => {    console.log('输出报错',e) })

到此,关于“Vue路由重复点击报错如何解决”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

--结束END--

本文标题: Vue路由重复点击报错如何解决

本文链接: https://lsjlt.com/news/355536.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作