vue的导航守卫

  • 全局的导航守卫

全局前置守卫: router.beforeEach()
全局解析守卫: router.beforeResolve()
全局后置钩子: router.afterEach(), 这个是不接受next参数的

  • 路由独享的守卫

beforeEnter() => {}

  • 组件内的守卫

beforeRouteEnter
beforeRouteUpdate
beforeRouteLeave

完整的导航解析流程

  1. 导航被触发。
  2. 在失活的组件里调用 beforeRouteLeave 守卫。
  3. 调用全局的 beforeEach 守卫。
  4. 在重用的组件里调用 beforeRouteUpdate 守卫 (2.2+)。
  5. 在路由配置里调用 beforeEnter。
  6. 解析异步路由组件。
  7. 在被激活的组件里调用 beforeRouteEnter。
  8. 调用全局的 beforeResolve 守卫 (2.5+)。
  9. 导航被确认。
  10. 调用全局的 afterEach 钩子。
  11. 触发 DOM 更新。
  12. 调用 beforeRouteEnter 守卫中传给 next 的回调函数,创建好的组件实例会作为回调函数的参数传入。

你可能感兴趣的:(vue的导航守卫)