一.router.beforeEach()是什么?
- 官方名称:全局前置守卫。(当一个导航触发时,全局前置守卫按照创建顺序调用。守卫是异步解析执行,此时导航在所有守卫 resolve 完之前一直处于等待中。)
- 个人通俗讲:就是看门的(你要进门,得有某某凭证才行,检查凭证的时候你得给我等着),也就是每一个router跳转以前都会调用的一个方法。
二.router.beforeEach长什么样?
router.beforeEach((to, from,next) => { // 返回 false 以取消导航 return false })
三.传递的参数解析
to
即将要进入的目标。比如说你在首页想要进入个人中心,此时个人中心
就是to
.from
当前导航正要离开的路由。比如说你正要从首页
跳转到个人中心,进入个人中心首先肯定是需要登录状态才能进入。当前我们所在的首页
就是from.next
一个函数,beforeEach()必须调用next()来resolved该钩子。
四.下面简单写个配置,便于理解,用了很多通俗的语言
// 路由前置守卫<