vue的导航钩子有3种:1、全局守卫钩子,是指路由示例上直接操作的钩子函数,特点是所有路由配置的组件都会触发。2、路由独享守卫钩子,是指在单个路由配置的时候也可以设置的钩子函数,且只能在这个路由下起作用。3、局部守卫钩子,是指在组件内执行的钩子函数,类似于数组内的生命周期函数,相当于为配置路由的组件添加的生命周期钩子函数。
本教程操作环境:windows7系统、vue3版,DELL G3电脑。
是指路由示例上直接操作的钩子函数,特点是所有路由配置的组件都会触发。简单点说就是触发路由就会触发这些钩子函数。钩子函数执行顺序包括beforeEach、beforeResolve、afterEach三个。
<code><strong>[beforeEach]</strong>
[beforeEach]
router.beforeEach router.beforeResolve router.afterEach const router = new VueRouter({ ... }); router.beforeEach((to, from, next) => { // do someting });
<strong>[beforeResolve]</strong>
:这个钩子和beforeEach类似,也是路由跳转前触发,参数也是to,from,next三个,和beforeEach区别官方解释为:区别是在导航被确认之前,同时在所有组件内守卫和异步路由组件被解析之后,解析守卫就会被调用。
即在beforeEach和组件内beforeRouteEnter之后,afterEach之后,afterEach之前调用。<strong>[afterEach]</strong>
<pre class="brush:js;toolbar:false;"> const router = new VueRouter({ ... });
router.beforeEach((to, from, next) => {
// do someting
});
//全局后置钩子,后置钩子并没有 next 函数,也不会改变导航本身
router.afterEach((to, from) => {
// do someting
});</pre>[afterEach]<h3></h3>
:和beforeEach相反,它是在路由跳转完成之后触发,参数包括to、from,没有了next,它发生在beforeEach和beforeResolve之后,beforeRouteEnter(足迹按内守卫)之前。2、路由独享守卫是指在单个路由配置的时候也可以设置的钩子函数,且只能在这个路由下起作用。其位置如下,也就是像File这样的组件都存在这样的钩子函数。目前它只有一个钩子函数beforeEnter。[beforeEnter]
cont router = new VueRouter({ routes: [ { path: '/file', component: File, beforeEnter: (to, from ,next) => { // do someting } } ] });
3、局部守卫
const File = { template: `<div>This is file</div>`, beforeRouteEnter(to, from, next) { // do someting // 在渲染该组件的对应路由被 confirm 前调用 }, beforeRouteUpdate(to, from, next) { // do someting // 在当前路由改变,但是依然渲染该组件是调用 }, beforeRouteLeave(to, from ,next) { // do someting // 导航离开该组件的对应路由时被调用 } }
是指在组件内执行的钩子函数,类似于数组内的生命周期函数,相当于为配置路由的组件添加的生命周期钩子函数。钩子函数按执行顺序包括beforeRouteEnter、beforeRouteUpdate(2.2新增)、beforeRouteLeave三个,执行位置如下:
路由跳转导航解析流程,当由A路由–>B路由的时候 1、在A组件里调用离开守卫。 A组件中的beforeRouterLeave2、调用全局的beforeEach守卫。 router.beforeEachroutes:[ { path:'/b', component:B, beforeEnter:(to,form,next)=>{ ..... } } ]
3、再执行B路由配置里调用beforeEnter。
4、再执行B组件的进入守卫。 B组件中beforeRouterEnter5、调用全局的beforeResolve守卫(2.5 )。 router.beforeResolve6、导航被确认。7、调用全局的afterEach钩子。 router.afterEach8、触发DOM更新。【相关推荐:vuejs视频教程
、web前端开发】以上是vue的导航钩子有哪几个的详细内容。更多信息请关注PHP中文网其他相关文章!