vue导航守卫有哪些

路由的钩子函数有六个

全局的路由钩子函数:beforeEach、afterEach
单个路由的钩子函数:beforeEnter
组件内路由钩子函数:beforeRouteEnter、beforeRouteUpdate、beforeRouteLeave

全局路由钩子函数

  1. 全局前置守卫: beforeEach(to, from, next)
  • router.beforeEach: 在每次每一个路由改变的时候都会执行一遍

    • to:将要进入的路由对象

    • from: 当前正要离开的路由对象

    • next

      • next(),进入下一个路由,必须调用,不然不会跳转

      • next(false): 中断当前的导航。如果浏览器的 URL 改变了 (可能是用户手动或者浏览器后退按钮),那么 URL 地址会重置到 from 路由对应的地址。

      • next(’/’) 或者 next({ paht:’/’}):跳转到一个不同的地址。当前的导航会被中断,然后进行一个新的导航。可传递的参数可以是 router-link 标签中的 to 属性参数或 router.push 中的选项

应用场景:可进行一些页面跳转前处理,例如判断需要登录的页面进行拦截,做登录跳转, 还有管理员权限判断。

  1. 全局后置守卫:afterEach(to, from)

router.afterEach: 和 beforeEach 相反,它是在路由跳转完成后触发,它发生在 beforeEach 之后 beforeRouteEnter(组件内守卫) 之前, 因为是跳转完成后触发,所以没有 next 参数。

路由内的钩子函数

  1. 路由独享守卫:beforeEnter(to, from, next)

和 beforeEach 完全相同,如果两个都设置了,beforeEnter 则在 beforeEach 之后紧随执行。在路由配置上直接定义 beforeEnter 守卫

组件内的钩子函数

 是指在组件内执行的钩子函数,类似于组件内的生命周期
  1. 组件前置守卫 beforeRouteEnter: 该钩子在全局守卫 beforeEach 和独享守卫 beforeEnter 之后。

  2. 组件更新守卫 beforeRouteUpdate:在当前路由改变时,并且该组件被复用时调用。

  3. 组件离开守卫 beforeRouteLeave:导航离开该组件的对应路由时调用

const Foo = {
    
    
  template: `...`,
  beforeRouteEnter (to, from, next) {
    
    
    // 在渲染该组件的对应路由被 confirm 前调用
    // 不!能!获取组件实例 `this`
    // 因为当钩子执行前,组件实例还没被创建
  },
  beforeRouteUpdate (to, from, next) {
    
    
    // 在当前路由改变,但是该组件被复用时调用
    // 举例来说,对于一个带有动态参数的路径 /foo/:id,在 /foo/1 和 /foo/2 之间跳转的时候,
    // 由于会渲染同样的 Foo 组件,因此组件实例会被复用。而这个钩子就会在这个情况下被调用。
    // 可以访问组件实例 `this`
  },
  beforeRouteLeave (to, from, next) {
    
    
    // 导航离开该组件的对应路由时调用
    // 可以访问组件实例 `this`
  }

猜你喜欢

转载自blog.csdn.net/qq_48960335/article/details/123818263