Vue导航守卫使用教程详解

 更新时间:2023年04月11日 10:32:28   作者:蒲公英想养花  
这篇文章主要介绍了Vue导航守卫使用教程,可以向任意给定的导航守卫传递next,但是next的使用过程容易出错,需要确保next在任何给定的导航守卫中都被严格调用一次

作用:通过跳转或取消的方式守卫导航

植入方式:

  • 全局守卫
  • 单个路由独享守卫
  • 组件级守卫

守卫参数

  • to: 即将要进入的目标路由
  • from: 当前导航即将要离开的路由
  • next(可选): 不传参默认去to路由,传参可改变目标路由

注意:可以向任意给定的导航守卫传递next,但是next的使用过程容易出错,需要确保next在任何给定的导航守卫中都被严格调用一次。(可以出现多于一次,但是只能在所有逻辑路径都不重叠的情况,否则钩子永远不会被解析或者报错)

守卫返回值

  • false: 取消当前导航
  • 路由地址:导航中断,跳转到返回的路由地址。(例如:return {name:‘login’}跳转到登陆页)
  • undefined/true: 导航有效,调用下一个导航守卫
  • 注意:如果有错误,会取消导航并调用router.onError()

全局守卫

全局前置守卫

const router = createRouter({...})
router.beforeEach((to, from) => {
})
  • 导航触发时,全局前置守卫按照创建顺序调用
  • 守卫是异步解析执行,导航在所有守卫resolve完之前一直处于等待

全局解析守卫

router.beforeResolve(async to => {
})
  • 在导航被确认之前,在所有组件内守卫和异步路由组件被解析之后调用
  • 是获取数据或避免用户无法进入页面时执行操作的理想位置

全局后置钩子

router.afterEach((to, from) => {
})
  • 和守卫的区别:不会接收next函数,也不会改变导航
  • 作用:分析/更改页面标题,声明页面等

单个路由独享守卫

const routes = [{
    path: '/users/:id',
    component: UserDetails,
    beforeEnter: (to, from) => {
    },
    // beforeEnter: [removeQuery, removeHash]
}]
  • 只在进入路由时触发,不会在params/query/hash改变时触发(如:/user/1 -> /user/2)
  • 传参:可以传递函数数组,有利于重用守卫

组件级守卫

  • beforeRouteEnter: 在渲染该组件对应路由被验证前调用,不能获取this
  • beforeRouteUpdate: 在组件被复用时调用,可以访问this
  • beforeRouteLeave: 在导航离开该组件路由时调用,可以访问this

注意:beforeRouteEnter 是支持给 next 传递回调的唯一守卫

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

离开守卫:通常用来预防用户在还未保存修改前突然离开,可以通过返回false来取消

完整的导航解析流程

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

总结

全局守卫

  • beforeEach
  • beforeResolve
  • beforeAfter:不接收next

单个路由独享守卫

  • beforeEnter:路由参数变化不触发

组件级守卫

  • beforeRouteEnter: 不可访问this
  • beforeRouteUpdate:可以访问this
  • beforeRouteLeave:可以访问this

到此这篇关于Vue导航守卫使用教程详解的文章就介绍到这了,更多相关Vue导航守卫内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vue计算属性get和set用法示例

    vue计算属性get和set用法示例

    这篇文章主要介绍了vue计算属性get和set用法,结合实例形式分析了计算属性的功能及get和set用法的具体使用技巧,需要的朋友可以参考下
    2019-02-02
  • 创建nuxt.js项目流程图解

    创建nuxt.js项目流程图解

    Nuxt.js是创建Universal Vue.js应用程序的框架。它的主要范围是UI渲染,同时抽象出客户端/服务器分布。我们的目标是创建一个足够灵活的框架,以便您可以将其用作主项目库或基于Node.js的当前项目。
    2020-03-03
  • vue3中封装axios请求最新实现步骤

    vue3中封装axios请求最新实现步骤

    这篇文章主要给大家介绍了关于vue3中封装axios请求的最新实现步骤,在Vue 3中可以通过封装axios来实现接口的统一管理和调用,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-04-04
  • VUE零基础入门axios的使用

    VUE零基础入门axios的使用

    这篇文章主要介绍了axios在Vue项目中用来向后台发送请求(调接口API),获取响应信息的方法,axios 是一个轻量的 HTTP客户端,基于 XMLHttpRequest 服务来执行 HTTP 请求,需要的朋友们下面随着小编来一起学习学习吧
    2022-07-07
  • Vue使用Tinymce富文本自定义toolbar按钮的实践

    Vue使用Tinymce富文本自定义toolbar按钮的实践

    本文主要介绍了Vue使用Tinymce富文本自定义toolbar按钮,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-12-12
  • vue3 实现右键菜单编辑复制粘贴功能

    vue3 实现右键菜单编辑复制粘贴功能

    在浏览器中,Vue3编辑器自带默认右键菜单,然而,在Electron桌面应用中,这一功能需自行编写代码实现,本文详细介绍了如何在Vue3中手动实现右键菜单的编辑、复制、粘贴功能,并提供了代码示例,更多细节和相关教程可参考脚本之家的其他文章
    2024-10-10
  • .netcore+vue 实现压缩文件下载功能

    .netcore+vue 实现压缩文件下载功能

    这篇文章主要介绍了.netcore+vue 实现压缩文件下载功能,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-09-09
  • vue实现表格增删改查效果的实例代码

    vue实现表格增删改查效果的实例代码

    本篇文章主要介绍了vue实现增删改查效果的实例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-07-07
  • vue封装swiper代码实例解析

    vue封装swiper代码实例解析

    这篇文章主要介绍了vue封装swiper代码实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-10-10
  • vue Element左侧无限级菜单实现

    vue Element左侧无限级菜单实现

    这篇文章主要介绍了vue Element左侧无限级菜单实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-06-06

最新评论