vue-router在升级之后,如果在main.js里面beforeEach钩子函数中全局拦截是否需要登陆,在跳转到登陆页面的时候会报错,如图所示:
解决方法一:
在router.js文件中添加一下代码
import Vue from 'vue'
import VueRouter from 'vue-router'
Vue.use(VueRouter)
//解决Vue-Router升级导致的重定向报错
const originalPush = VueRouter.prototype.push
VueRouter.prototype.push = function push(location, onResolve, onReject) {
if (onResolve || onReject)
return originalPush.call(this, location, onResolve, onReject)
return originalPush.call(this, location).catch(err => err)
}
解决方法二:
手动在backage.json文件中将vue-router的版本改为3.0.1,然后npm重新安装依赖
博客指出vue-router升级后,在main.js的beforeEach钩子函数中全局拦截登录状态,跳转到登录页面会报错。并给出两种解决方法,一是在router.js文件添加代码,二是手动在backage.json文件中将vue-router版本改为3.0.1,再重新安装依赖。

7723

被折叠的 条评论
为什么被折叠?



