- 为什么?
push方法会返回一个Promise对象,内部会进行跳转成功或失败的回调 - 解决方法
只需在push方法末尾传递两个成功和失败的回调函数,可以捕获到当前的错误,可以解决。但是此种方法治标不治本,可以解决警告错误
将来在其他组件中使用push或replace时还会报错 - 我们知道push方法是VueRouter类的一个原型方法,而$router是VueRouter类的实例,类的实例可以直接调用类的原型方法,所以治本的方法在于直接重写原型方法push,修改结果就会作用于以后使用push。
所以问题的究极解决方法是在配置路由的js文件里,重写原来的push方法
如下
// 先把VueRouter的原型对象的push方法保存一份
let originPush = VueRouter.prototype.push
// 重写push|replace
// 第一个参数:告诉原来的push方法跳转到哪个路由 ,即原来向push方法传递的参数
VueRouter.prototype.push = function (location, resolve, reject) {
if (resolve && reject) {
originPush.call(this, location, resolve, reject)
} else {
originPush.call(this, location, ()=>{}, ()=>{})
}
}
这样就解决了编程式导航重复跳转到当前路由的报错问题啦
版权声明:本文为cyj5201314原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。