多次触发编程式路由报错问题
Uncaught (in promise) NavigationDuplicated: Avoided redundant navigation to current location: "/?k="
由于vue-router最新版本3.5.2,引入了promise,当传递参数多次且重复,会抛出异常,因此出现上面现象,
第一种解决方案:是给push函数,传入相应的成功的回调与失败的回调
this.$router.push({name:'search',params:{keyword:this.keyword},query:{k:this.keyword.toUpperCase()}},()=>{},()=>{})
后面添加两个函数用来接收成功与失败的回调
第一种解决方案可以暂时解决当前问题,但是以后再用push|replace还是会出现类似现象,因此我们需要从‘根’治病;
第二种从根源解决多此触发编程式路由引发的错误,改写push方法
在路由配置中,改写push
/* 先把VueRouter原型对象的push,先保存一份 */
let originPush=VueRouter.prototype.push;
let originReplace = VueRouter.prototype.replace
//重写push|replace
/* 第一个参数:告诉原来的push方法,往哪里跳转 */
//重写push
VueRouter.prototype.push=function(location,resolve,reject){
if(resolve&&reject){
//call||apply区别
//相同点,都可以调用函数一次,都可以篡改函数的上下文一次
//不同点:call与apply传递参数:call传递参数用逗号隔开,apply方法执行。传递数组
//this还是用该上下文调用,也就是vuerouter的实例,后面跟参数指定跳的位置,以及成功失败的回调
originPush.call(this,location,resolve,reject)
}else{
originPush.call(this,location,()=>{},()=>{})
}
}
//重写replace
VueRouter.prototype.replace = function(location,resolve,reject){
if(resolve&&reject){
originReplace.call(this,location,resolve,reject)
}else{
originReplace.call(this,location,()=>{},()=>{})
}
}
this.$router.push({name:'search',params:{keyword:this.keyword},query:{kw:this.keyword.toUpperCase()}})
扩展知识
this :当前组件实例
this.$router属性:当前的这个属性是VueRouter类的一个实例,当在入口文件注册路由的时候,给组件实例添加$router|$route属性,可以this.$router可以使用原型中的方法