最近在使用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(),后者会!!!
官网这样写的(主要是红线标记的那句!):
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持北冥有鱼。
您可能感兴趣的文章:
- 浅谈vue.js中v-for循环渲染
- 浅析vue中常见循环遍历指令的使用 v-for
- vue中for循环更改数据的实例代码(数据变化但页面数据未变)
- vue使用Element组件时v-for循环里的表单项验证方法
- 详解使用vue实现tab 切换操作
- Vue.js组件tabs实现选项卡切换效果
- vue2.0实现导航菜单切换效果
- Vue.js组件tab实现选项卡切换
- 基于Vue实现tab栏切换内容不断实时刷新数据功能
- vue实现循环切换动画