使用VueRouter的导航守卫无限循环问题

1次阅读

共计 612 个字符,预计需要花费 2 分钟才能阅读完成。

我在项目里面用到了的是全局守卫,beforeEach, 方便管理
不过遇到了一个问题,就是在 beforeEach()中设置好判断条件后出现了无限循环的问题
当时的代码如下:

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

结果 chrome 的 debug 中看到:

这个问题我是这样理解的:
next() 表示路由成功,直接进入 to 路由,不会再次调用 router.beforeEach()
next(‘login’) 表示路由拦截成功,重定向至 login,会再次调用 router.beforeEach()
也就是说 beforeEach()必须调用 next(), 否则就会出现无限循环,next() 和 next(‘xxx’) 是不一样的,区别就是前者不会再次调用 router.beforeEach(),后者会!!!
官网这样写的(主要是红线标记的那句!):

最终解决的代码如下:

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

觉得有帮助的小伙伴右上角点个赞~

扫描上方二维码关注我的订阅号~

觉得有帮助的小伙伴点个赞支持下~

正文完
 0