vue路由守卫

作者: 我那么逗 | 来源:发表于2020-09-23 08:31 被阅读0次

概念

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

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

全局守卫

路由独享

路由组件中

1.全局守卫:

全局前置守卫beforeEach

全局前置守卫,可以使用路由的实例注册一个全局前置守卫   此守卫一般用于登录状态在未登录的状态下,进行守卫,直接跳转到登录页

全局解析守卫

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


全局后置守卫

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

2.路由独享


beforeEnter

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

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

3.组件内的守卫

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

beforeRouteEnter

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

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

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


beforeRouteUpdate

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

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


beforeRouteLeave

当离开时第一个触发

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

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


守卫参数解析

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

1.to

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

2.from

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

3.next ()

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

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

此函数的用法

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

next(false) 阻止当前的导航

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

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

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

相关文章

  • 华云

    一,vue路由守卫的生命周期1,全局的前置路由守卫 router.beforeEach()2, 全局解析守卫 ...

  • react实现路由守卫

    与vue不同,vue直接使用beforeEach即可实现全局路由守卫等功能。react要实现路由守卫得自己配置。实...

  • vue-router 常见导航守卫

    全局守卫vue-router全局有三个守卫 路由独享守卫如果你不想全局配置守卫的话,你可以为某些路由单独配置守卫 ...

  • vue 路由导航白话全解析

    这里先放上官网的教程和说明:点击这里,vue导航守卫官方文档 路由守卫 路由守卫说白了就是路由拦截,在地址栏跳转之...

  • Vue导航守卫

    Vue导航守卫 理解 导航守卫也叫路由守卫,可以实时的监控路由的跳转过程,在路由的跳转的各个过程执行相应的操作,有...

  • Vue-Router 导航守卫

    导航守卫 导航表示路由正在发生改变。(变化的路由)导航守卫就是变化的路由钩子。路由钩子的意思可以理解为vue-ro...

  • 关于vue路由守卫做登陆状态判断的问题

    关于vue路由守卫做登陆状态判断的问题 直接上代码 // 全局路由守卫 router.beforeEach((to...

  • Vue路由/路由守卫

    一、前端路由和后端路由概念解释 二、路由的基本使用方式 三、常见引入路由组件的方式和区别 四、常见引入路由分类1....

  • Vue - 路由守卫(路由的生命周期)

    路由守卫是什么? 官方解释:“导航”表示路由正在发生改变。正如其名,vue-router提供的导航守卫主要用来通过...

  • vue-router进阶

    导航守卫 vue-router 提供的导航守卫主要用来通过跳转或取消的方式守卫导航(路由发生改变才会守卫)。参数 ...

网友评论

    本文标题:vue路由守卫

    本文链接:https://www.haomeiwen.com/subject/ojsgyktx.html