vue-router 中的导航钩子

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了vue-router 中的导航钩子相关的知识,希望对你有一定的参考价值。

参考技术A 有三种方式可以植入路由导航过程中:
1、全局的
2、单个路由独享的
3、组件级的

全局导航钩子主要有两种钩子:前置守卫、后置钩子,

这三个参数 to 、from 、next 分别的作用:
to: Route,代表要进入的目标,它是一个路由对象
from: Route,代表当前正要离开的路由,同样也是一个路由对象
next: Function,这是一个必须需要调用的方法,而具体的执行效果则依赖 next 方法调用的参数

不同于前置守卫,后置钩子并没有 next 函数,也不会改变导航本身

至于他的参数的使用,和全局前置守卫是一样的

组件内的导航钩子主要有这三种:beforeRouteEnter、beforeRouteUpdate、beforeRouteLeave。他们是直接在路由组件内部直接进行定义的

我们看一下他的具体用法:

需要注意是:

beforeRouteEnter 不能获取组件实例 this,因为当守卫执行前,组件实例被没有被创建出来,剩下两个钩子则可以正常获取组件实例 this

但是并不意味着在 beforeRouteEnter 中无法访问组件实例,我们可以通过给 next 传入一个回调来访问组件实例。在导航被确认是,会执行这个回调,这时就可以访问组件实例了,如:

因为归根结底,支持回调是为了解决 this 问题,而其他两个钩子的 this 可以正确访问到组件实例,所有没有必要使用回调

以上是关于vue-router 中的导航钩子的主要内容,如果未能解决你的问题,请参考以下文章

vue-router有哪几种导航钩子( 导航守卫 )?

Vue-Router路由钩子函数(导航守卫)

vue-router导航守卫

vue-router的钩子函数

vue-router 钩子函数 (beforeEach、afterEach、beforeEnter)

Vue的路由Router之导航钩子和元数据及匹配