当前位置: 移动技术网 > IT编程>脚本编程>vue.js > 关于vue-router的beforeEach无限循环的问题解决

关于vue-router的beforeEach无限循环的问题解决

2017年12月12日  | 移动技术网IT编程  | 我要评论

天天赢28论坛,昆明多人持刀火拼,餐饮娱乐

最近在使用vue-router的beforeeach钩子时候遇到了一个问题,就是在beforeeach()中设置好判断条件后出现了无限循环的问题
代码如下:

router.beforeeach((to, from, next) => {
 if(islogin){
  next()
 }else{
  console.log('测试')
  next('login')
 }
})

结果chrome的debug中看到:

这个问题我是这样理解的:

router.beforeeach((to, from, next) => {
  if(true){
    next()
  }else{
    next('login')
  }
})
  • next() 表示路由成功,直接进入to路由,不会再次调用router.beforeeach()
  • next('login') 表示路由拦截成功,重定向至login,会再次调用router.beforeeach()

也就是说beforeeach()必须调用next(),否则就会出现无限循环,next() 和 next('xxx') 是不一样的,区别就是前者不会再次调用router.beforeeach(),后者会!!!

官网这样写的(主要是红线标记的那句!):

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网