Vue中的路由导航守卫有哪些?它们的执行顺序是什么?

简介: Vue中的路由导航守卫有哪些?它们的执行顺序是什么?

在 Vue 中,有以下三种路由导航守卫:

  • 全局守卫:
    • router.beforeEach:在进入每个路由之前执行。回调函数中有三个参数,to表示进入到哪个路由,from表示从哪个路由离开,next是一个函数,用于决定是否展示要看到的路由页面。
    • router.afterEach:在离开每个路由之后执行。回调函数中有两个参数,to表示进入到哪个路由,from表示从哪个路由离开。
  • 组件内的守卫:
    • beforeRouteEnter:在进入组件时执行。回调函数中有三个参数,tofrom参数的含义与全局守卫中的一致,next回调函数略有不同。如果直接以beforeRouteEnter进行访问,会发现alert输出hello undefined,这是因为在执行完之前,data数据还未渲染。所以,next会给一个对应的回调,帮助完成。
    • beforeRouteLeave:在离开组件时执行。如果确认离开,执行next();如果取消,执行next(false),留在当前页面。
  • 路由独享的守卫:
    • beforeEnter:用法与全局守卫一致。

执行顺序如下:

  1. 全局守卫的router.beforeEach
  2. 路由独享的守卫的beforeEnter
  3. 组件内的守卫的beforeRouteEnter
  4. 全局守卫的router.afterEach
  5. 组件内的守卫的beforeRouteLeave
  6. 路由独享的守卫的beforeEnter
相关文章
|
资源调度 JavaScript 前端开发
路由管理:Vue Router的使用和配置技巧
【10月更文挑战第21天】路由管理:Vue Router的使用和配置技巧
311 3
|
JavaScript
Vue 的父组件和子组件生命周期钩子执行顺序
在 Vue 中,父组件和子组件的生命周期钩子执行顺序如下:
|
JavaScript
|
JavaScript API
vue 批量自动引入并注册组件或路由等等
【10月更文挑战第12天】 vue 批量自动引入并注册组件或路由等等
|
JavaScript UED
"Vue实战技巧大揭秘:一招解决路由跳转页面不回顶部难题,让你的单页面应用用户体验飙升!"
【10月更文挑战第23天】在Vue单页面应用中,点击路由跳转时,默认情况下页面不会自动滚动到顶部,这可能影响用户体验。本文通过一个新闻网站的案例,介绍了如何使用Vue-router的全局前置守卫和`scrollBehavior`方法,实现路由跳转时页面自动滚动到顶部的功能,提升用户浏览体验。
640 0
|
JavaScript API
Vue中使用require.context()自动引入组件和自动生成路由的方法介绍
Vue中使用require.context()自动引入组件和自动生成路由的方法介绍
560 0
|
存储 前端开发 JavaScript
为什么我不再用Vue,改用React?
当我走进现代前端开发行业的时候,我做了一个每位开发人员都要做的决策:选择一个合适的框架。当时正逢 jQuery 被淘汰,前端开发者们不再用它编写难看的、非结构化的老式 JavaScript 程序了。
|
5月前
|
JavaScript
Vue中如何实现兄弟组件之间的通信
在Vue中,兄弟组件可通过父组件中转、事件总线、Vuex/Pinia或provide/inject实现通信。小型项目推荐父组件中转或事件总线,大型项目建议使用Pinia等状态管理工具,确保数据流清晰可控,避免内存泄漏。
502 2
|
4月前
|
缓存 JavaScript
vue中的keep-alive问题(2)
vue中的keep-alive问题(2)
426 137
|
8月前
|
人工智能 JavaScript 算法
Vue 中 key 属性的深入解析:改变 key 导致组件销毁与重建
Vue 中 key 属性的深入解析:改变 key 导致组件销毁与重建
975 0