这篇文章主要介绍“vue路由钩子函数是哪几种”,在日常操作中,相信很多人在vue路由钩子函数是哪几种问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue路由钩子函数是哪几种”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
“只有客户发展了,才有我们的生存与发展!”这是创新互联公司的服务宗旨!把网站当作互联网产品,产品思维更注重全局思维、需求分析和迭代思维,在网站建设中就是为了建设一个不仅审美在线,而且实用性极高的网站。创新互联对网站建设、网站设计、网站制作、网站开发、网页设计、网站优化、网络推广、探索永无止境。
vue路由钩子函数有2种,分别为:1、全局守卫(全局钩子函数),指的是“index.js”中的router对象;2、路由守卫(针对单个路由钩子函数);3、组件守卫(组件级钩子函数),是定义在路由组件内部的守卫。

本教程操作环境:windows7系统、vue2.9.6版,DELL G3电脑。
vue-router 的 钩子函数,其实说的就是 导航守卫。
引用官网的话
“导航” 表示路由正在发生改变。
vue-router提供的导航守卫主要用来通过 跳转或 取消的方式 守卫导航。有多种机会植入路由导航过程中:全局的, 单个路由独享的, 或者组件级的。
也就是:全局守卫(全局钩子函数)、路由守卫(针对单个路由钩子函数)、组件守卫(组件级钩子函数)。
先简单搭建一下环境
index.js
import { createRouter, createWebHashHistory } from 'vue-router';
const router = createRouter({
history: createWebHashHistory(),
routes: [
{
path: '/a',
component: () => import('../components/A.vue'),
},
{
path: '/b',
component: () => import('../components/B.vue'),
},
{
path: '/c',
component: () => import('../components/C.vue'),
},
],
});
export default router;main.js
// index.js
import router from "./router";
createApp(App).use(router).mount("#app");页面A
我是页面A啊
页面B
我是页面B啊
页面C
我是页面C啊
通用组件
我是公用组件啊
当前页面是这样的,有点丑,凑活看吧,咱也不是来学习 css 的

顾名思义,是要定义在全局的,也就是我们 index.js 中的 router 对象。
全局前置守卫,在路由跳转前触发,它在 每次导航时都会触发。
通过 router.beforeEach 注册一个全局前置守卫。

beforeEach 全局前置守卫接收三个参数
to: Route: 即将要进入的目标路由对象
from: Route: 当前导航正要离开的路由对象
next: Function: 一定要调用该方法不然会阻塞路由。
注意:next 参数可以不添加,但是一旦添加,则必须调用一次,否则路由跳转等会停止。
next()方法的几种情况
next():进行管道中的下一个钩子。
next(false):中断当前的导航。回到 from 路由对应的地址。
next(’/’) 或者 next({ path: ‘/’ }):跳转到一个不同的地址,可传递的参数与 router.push 中选项一致。
next(error):导航终止,且该错误会被传递给 router.onError() 注册过的回调。
我们把前两个参数打印出来看一下,里面包含路径,参数,元信息等内容。

false:取消当前的导航。
null,undefined,true或者直接return:调用下一个导航守卫。
全局前置守卫可以定义多个,根据创建顺序调用。在所有守卫完成之前导航一直处于等待中。
下面这个例子中我们就定义了两个 beforeEach 全局前置守卫。可以看到,只有在两秒以后分别打印出两条日志后才进行页面的跳转。


除了 beforeEach 全局前置守卫之外,其他的全局守卫都可以定义多个,并且在所有守卫完成之前导航一直处于等待中,其他的钩子函数就不进行演示了。
全局解析守卫,在路由跳转前,所有 组件内守卫和 异步路由组件被解析之后触发,它同样在 每次导航时都会触发。
通过 router.beforeResolve 注册一个全局解析守卫。
router.beforeResolve((to, from, next) => {
next();
})回调参数,返回值和 beforeEach 一样。也可以定义多个全局解析守卫。
全局后置钩子,它发生在路由跳转完成后,beforeEach 和 beforeResolve 之后,beforeRouteEnter(组件内守卫)之前。它同样在 每次导航时都会触发。
通过 router.afterEach 注册一个全局后置钩子。

这个钩子的两个参数和 beforeEach 中的 to 和 from 一样。然而和其它全局钩子不同的是,这些钩子不会接受 next 函数,也不会改变导航本身。
顾名思义,就是跟路由相关的钩子,我们的路由守卫只有一个,就是 beforeEnter。
需要在路由配置上定义 beforeEnter 守卫,此守卫只在进入路由时触发,在 beforeEach 之后紧随执行,不会在 params、query 或 hash 改变时触发。

beforeEnter 路由守卫的参数是 to、from、next ,同 beforeEach 一样。
顾名思义,是定义在路由组件内部的守卫。

路由进入组件之前调用,该钩子在全局守卫 beforeEach 和路由守卫 beforeEnter 之后,全局 beforeResolve 和全局 afterEach 之前调用。
参数包括 to,from,next。
该守卫内访问不到组件的实例,也就是 this 为 undefined,也就是他在 beforeCreate 生命周期前触发。

对于 beforeRouteUpdate 来说,this 已经可用了,所以给 next 传递回调就没有必要了。

对于 beforeRouteLeave 来说,this 已经可用了,所以给 next 传递回调就没有必要了。
导航被触发。
在失活的组件里调用
beforeRouteLeave守卫。调用全局的
beforeEach守卫。在重用的组件里调用
beforeRouteUpdate守卫。在路由配置里调用
beforeEnter。解析异步路由组件。
在被激活的组件里调用
beforeRouteEnter。调用全局的
beforeResolve守卫。导航被确认。
调用全局的
afterEach钩子。触发
DOM更新。调用
beforeRouteEnter守卫中传给next的回调函数,创建好的组件实例会作为回调函数的参数传入。
上面是官方给出的答案,现在我们用流程图来直观的展示一下。

到此,关于“vue路由钩子函数是哪几种”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注创新互联网站,小编会继续努力为大家带来更多实用的文章!