vue-router的导航钩子

 vue-router的导航钩子?

vue-router有三种导航钩子

1.全局的

2.单个路由独享的

3.组件级的

1. 全局导航钩子:

全局导航钩子主要有两种钩子:前置守卫(router.beforeEach)、后置钩子(router.afterEach),

注册一个全局前置守卫:

const router = new VueRouter({ ... });

router.beforeEach((to, from, next) => {

    // do someting

});

这三个参数 to 、from 、next 分别的作用:

1.to: Route,代表要进入的目标,它是一个路由对象

2.from: Route,代表当前正要离开的路由,同样也是一个路由对象

3.next: Function,这是一个必须需要调用的方法,而具体的执行效果则依赖 next 方法调用的参数

注意:next 方法必须要调用,否则钩子函数无法 resolved

对于全局后置钩子:

router.afterEach((to, from) => {

    // do someting

});

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

2. 路由独享的钩子

顾名思义,即单个路由独享的导航钩子,它是在路由配置上直接进行定义的:

const router = new VueRouter({

    routes: [

        {

            path: '/file',

            component: File,

            beforeEnter: (to, from ,next) => {

                // do someting

            }

        }

    ]

});

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

3. 组件内的导航钩子

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

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

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

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

beforeRouteEnter(to, from, next) {

    next (vm => {

        // 这里通过 vm 来访问组件实例解决了没有 this 的问题

    })

}

注意,仅仅是 beforRouteEnter 支持给 next 传递回调,其他两个并不支持。因为归根结底,支持回调是为了解决 this 问题,而其他两个钩子的 this 可以正确访问到组件实例,所有没有必要使用回调

最后是完整的导航解析流程:

1、导航被触发

2、在失活的组件里调用离开守卫

3、调用全局的 beforeEach 守卫

4、在重用的组件里调用 beforeRouteUpdate 守卫

5、在路由配置里调用 beforEnter

6、解析异步路由组件

7、在被激活的组件里调用 beforeRouteEnter

8、调用全局的 beforeResolve 守卫

9、导航被确认

10、调用全局的 afterEach 钩子

11、触发 DOM 更新

12、在创建好的实例调用 beforeRouteEnter 守卫中传给 next 的回调函数

posted @ 2020-12-28 10:28  Hat-boy  阅读(1500)  评论(0)    收藏  举报