简述vue-router 路由钩子函数是什么?执行顺序是什么?

Vue-Router的路由钩子函数是在路由跳转的不同阶段执行的函数,用于在路由发生变化时执行特定的操作或逻辑。这些钩子函数允许开发者在路由进入、离开或更新时添加自定义行为。

Vue-Router的路由钩子函数可以分为以下几类:

  1. 全局钩子函数

    • beforeEach:在路由跳转之前执行,可以用于进行权限判断、加载数据等操作。该函数接收三个参数:to(即将进入的路由对象)、from(当前导航即将离开的路由对象)和next(一个必须调用的函数,用于解析钩子)。
    • beforeResolve(2.5+):在路由被解析之后,但在组件被渲染之前执行。
    • afterEach:在路由跳转之后执行,通常用于进行页面跳转后的收尾工作,如页面标题的更新等。
  2. 路由独享的钩子函数

    • beforeEnter:在路由配置中定义,只在进入该路由时执行。
  3. 组件内的钩子函数

    • beforeRouteEnter:在路由进入之前被调用,此时组件实例还未被创建,不能访问this
    • beforeRouteUpdate(2.2+):在当前路由改变,但是该组件被复用时调用,如路由参数变化时。
    • beforeRouteLeave:在离开当前路由时调用。

执行顺序

  1. 导航被触发。
  2. 在失活的组件里调用beforeRouteLeave守卫。
  3. 调用全局的beforeEach守卫。
  4. 在重用的组件里调用beforeRouteUpdate守卫(2.2+)。
  5. 在路由配置里调用beforeEnter
  6. 解析异步路由组件。
  7. 在被激活的组件里调用beforeRouteEnter
  8. 调用全局的beforeResolve守卫(2.5+)。
  9. 导航被确认。
  10. 调用全局的afterEach钩子。

这些钩子函数允许开发者在路由的不同阶段添加自定义逻辑,从而实现更复杂的路由导航控制和组件状态管理。

相关推荐
_龙衣10 分钟前
将 swagger 接口导入 apifox 查看及调试
前端·javascript·css·vue.js·css3
进取星辰1 小时前
25、Tailwind:魔法速记术——React 19 样式新思路
前端·react.js·前端框架
struggle20251 小时前
continue通过我们的开源 IDE 扩展和模型、规则、提示、文档和其他构建块中心,创建、共享和使用自定义 AI 代码助手
javascript·ide·python·typescript·开源
x-cmd2 小时前
[250512] Node.js 24 发布:ClangCL 构建,升级 V8 引擎、集成 npm 11
前端·javascript·windows·npm·node.js
夏之小星星2 小时前
el-tree结合checkbox实现数据回显
前端·javascript·vue.js
crazyme_62 小时前
前端自学入门:HTML 基础详解与学习路线指引
前端·学习·html
撸猫7912 小时前
HttpSession 的运行原理
前端·后端·cookie·httpsession
亦世凡华、3 小时前
Rollup入门与进阶:为现代Web应用构建超小的打包文件
前端·经验分享·rollup·配置项目·前端分享
琉璃℡初雪3 小时前
vue2/3 中使用 @vue-office/docx 在网页中预览(docx、excel、pdf)文件
vue.js·pdf·excel
Bl_a_ck3 小时前
【React】Craco 简介
开发语言·前端·react.js·typescript·前端框架