脚本宝典收集整理的这篇文章主要介绍了关于vue-router的beforeEach无限循环的问题,脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
最近在使用vue-router的beforeeach钩子时候遇到了一个问题,就是在beforeEach()中设置好判断条件后出现了无限循环的问题
代码如下:
// isLogined 用来判断用户是否已登录
router.beforeEach((to, From, next) => {
if(isLogined){
next()
}else{
console.log('测试')
next('login')
}
})
结果chrome的debug中看到:
这个问题我是这样理解的:
router.beforeEach((to, from, next) => {
if(true){
next()
}else{
next('login')
}
})
也就是说beforeEach()必须调用next(),否则就会出现无限循环,
next() 和 next('xxx') 是不一样的,区别就是前者不会再次调用router.beforeEach(),后者会!!!
官网这样写的(主要是红线标记的那句!):
So.... 如果为你解惑了,点个赞呗~ 如果我理解的有误,请指正~
以上是脚本宝典为你收集整理的关于vue-router的beforeEach无限循环的问题全部内容,希望文章能够帮你解决关于vue-router的beforeEach无限循环的问题所遇到的问题。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。