Vue-Router之路由守卫

Vue-路由守卫

一.概念

路由守卫,官网也叫导航守卫,所谓导航,就是路由正在发生变化

路由守卫,主要就是用来通过跳转或取消的方式守卫导航,在导航过程中,有三种方式可以植入导航

  • 全局守卫
  • 路由独享
  • 路由组件中

二.守卫类型

1.全局守卫

1.1.全局前置守卫beforeEach

全局前置守卫,可以使用路由的实例注册一个全局前置守卫

router.beforeEach((to,from,next)=>{
    
});

此守卫一般用于登录状态在未登录的状态下,进行守卫,直接跳转到登录页

// 全局路由守卫:会拦截所有的路由跳转行为
// 常用于实现登录拦截
router.beforeEach((to, from, next) => {
  // console.log(to, from)
  // 只对访问购物车组件的路由跳转行为进行拦截
  if (to.fullPath=='/cart' || to.fullPath=='/user') {
    let token = localStorage.getItem('token')
    if(token) {
      next()
    } else {
      next('/login')
    }
  } else {
    next()
  }
})
1.2 全局解析守卫

与router.beforeEach差不多,但是区别是,在导航被确认之前,所有组件内守卫和异步路由组件都解析成功之后,才会被调用

router.beforeResolve((to,from,next)=>{
    
});
1.3全局后置守卫

全局后置守卫,导航已经完成了触发,不会接受next函数,也不能使用next来改变路由

router.afterEach((to,from)=>{
    //不接受next函数,也无法改变路由
});

2.路由独享

1.beforeEnter

在某一个路由规则触发时触发,所以用法就是在路由规则的配置上触发一个钩子函数 beforeEnter()

var router=new VueRouter({
	routes:[
        {
            path:'/index',
            component:Inex,
             //路由独享
            beforeEnter: (to, from, next) => {

            }
        }
    ]
});

一般用处就是当不需要全局路由守卫时,只需要对一个路由规则进行守卫时使用,看具体场景,开发中,一般全局前置守卫用的比较多

3.组件内的守卫

在组件的配置选项中定义的的钩子函数

3.1.beforeRouteEnter

在组件内配置的 触发在beforeEnter之前

不能获取该组件的实例对象this,因为此守卫在执行前,组件实例还没有被创建

此守卫是唯一支持给next传递回调的守卫,虽然无法访问到组件实例,但是可以通过回调的方式获取

beforeRouteEnter (to, from, next) {
  next(vm => {
    // 通过 `vm` 访问组件实例
  })
}
3.2 beforeRouteUpdate

在动态路由的时候,参数发生变化时触发

在当前的路由改变的时候,也就是此组件被复用时触发比如带有动态参数的路径 /index/:id /index/1跳转到/index/2的时候会触发此守卫 可以访问组件实例this

beforeRouteEnter (to, from, next) {
  next(vm => {
    // 通过 `vm` 访问组件实例
  })
}
3.3 beforeRouteLeave

当离开时第一个触发

也就是导航离开这个组件的对应路由时被调用.可以访问组件实例this

此导航的应用一般用于:比如用户在还未保存修改前突然离开,改导航可以通过next(false来取消)

beforeRouteLeave (to, from, next) {
  const answer = window.confirm('Do you really want to leave? you have unsaved changes!')
  if (answer) {
    next()
  } else {
    next(false)
  }
}

三完整导航解析流程

在这里插入图片描述

  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 的回调函数。

四.解析流程示例

1.home===>list

  • 1./home组件中的beforeRouteLeave
  • 2.全局前置beforeEach
  • /list配置中触发beforeEnter
  • 4./list组件中的beforeRouteEnter
  • 5.全局后置 afterEach

2./details/1===>/details/2

只会触发是三种

  • 1.全局前置 beforeEach
  • 2.detail组件中的beforeRouteUpdate
  • 3.全局后置 afterEach

五,守卫参数解析

每个守卫方法都接收是三个参数 to from next()

1.to

即将去的目标 通俗来说就是到哪里去

2.from

即将离开的路由 通俗来说就是从哪里来

3.next ()

是一个方法,必须调用,一定要调用这个方法来解析,执行效果依赖next方法的调用参数

注意使用时,一定要保证不要造成死循环

此函数的用法

  • next() 进行下一个,执行下一步

  • next(false) 阻止当前的导航

  • next(’/’)后者next({path:’/’})

    跳转到一个不同的地址,当前的导航中断,跳转到一个新的导航

  • next(error) 如果传入的参数是一个Error实例,导航终止,并该错误会传递给router.onError()注册过的回调

猜你喜欢

转载自blog.csdn.net/liuqiao0327/article/details/106888959