Vue router / Element 重复点击导航路由报错解决方法

写 Vue 项目中,使用 Element-ui 重复点击导航路由会报错,报错信息如下:

在这里插入图片描述

虽然此报错并不会影响项目运行,但是作为一个强迫症的码农的确受不了error,解决方法如下:

方法①:把项目依赖的 node_modules 文件夹删除, 然后再 npm install 重新下载依赖包,如果安装的 vue-router 还是之前出错的那个版本,在项目目录下运行 npm i [email protected] -S 重新下载未出错版本即可;
在这里插入图片描述

提示:vue-router 官方在 2019-08-06 推出的 [email protected] 已经修复了此 bug,目前安装 3.1.1 以上的 vue-router 版本既可解决此报错。

备注:官方上确实展示目前版本已修复了此问题,不知为何有些高版本的vue-router还是会报错,这种情况下建议大家采用方法二,即可解决此问题。

方法②:不想更换 vue-router 的版本亦可,在 main.js 或 router.js 中添加以下代码:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-4JqhadkQ-1587785779545)(https://blog.csdn.net/l508742729/article/details/102526293)]

import Router from 'vue-router'
 
// 解决重复点击导航路由报错
const originalPush = Router.prototype.push;
Router.prototype.push = function push(location) {
  return originalPush.call(this, location).catch(err => err);
}

方法③:在路由地址后面中添加以下代码:

this.$router.push('xxxx').catch(err => err) 

Vue router / Element 重复点击导航路由报错解决方法_第1张图片

如有更好的解决方案,欢迎留言指正!

你可能感兴趣的:(Vue router / Element 重复点击导航路由报错解决方法)