zoukankan      html  css  js  c++  java
  • Vue里面提供的三大类钩子及两种函数

    在路由跳转的时候,我们需要一些权限判断或者其他操作。这个时候就需要使用路由的钩子函数。

    定义:路由钩子主要是给使用者在路由发生变化时进行一些特殊的处理而定义的函数。

    总体来讲vue里面提供了三大类钩子,两种函数
    1、全局钩子
    2、某个路由的钩子
    3、组件内钩子

    两种函数:

    1、Vue.beforeEach(function(to,form,next){}) /*在跳转之前执行*/

    2.Vue.afterEach(function(to,form))/*在跳转之后判断*/

    全局钩子函数

    顾名思义,它是对全局有效的一个函数

    1
    2
    3
    4
    5
    6
    router.beforeEach((to, from, next) => {
        let token = router.app.$storage.fetch("token");
        let needAuth = to.matched.some(item => item.meta.login);
        if(!token && needAuth) return next({path: "/login"});
        next();
    });

    beforeEach函数有三个参数:

    • to:router即将进入的路由对象
    • from:当前导航即将离开的路由
    • next:Function,进行管道中的一个钩子,如果执行完了,则导航的状态就是 confirmed (确认的);否则为false,终止导航。

    afterEach函数不用传next()函数

    某个路由的钩子函数

    顾名思义,它是写在某个路由里头的函数,本质上跟组件内函数没有区别。

    复制代码
    const router = new VueRouter({
      routes: [
        {
          path: '/login',
          component: Login,
          beforeEnter: (to, from, next) => {
            // ...
          },
          beforeLeave: (to, from, next) => {
            // ...
          }
        }
      ]
    })
    复制代码

    路由组件的钩子

    注意:这里说的是路由组件!

    路由组件 属于 组件,但组件 不等同于 路由组件!所谓的路由组件:直接定义在router中component处的组件。如:

    复制代码
    var routes = [
        {
        path:'/home',
        component:home,
        name:"home"
        }
    ]
    复制代码

    在子组件中调用路由的钩子函数时无效的。

    在官方文档上是这样定义的:

    可以在路由组件内直接定义以下路由导航钩子
    beforeRouteEnter
    beforeRouteUpdate (2.2 新增)
    beforeRouteLeave

    这里简单说下钩子函数的用法:它是和data,methods平级的。

    复制代码
    beforeRouteLeave(to, from, next) {
        next()
    },
    beforeRouteEnter(to, from, next) {
        next()
    },
    beforeRouteUpdate(to, from, next) {
        next()
    },
    data:{},
    method: {}
    复制代码
  • 相关阅读:
    韩信点兵 中国剩余定理
    A -- A. Quailty and Playing Cards 模拟 + 思考
    HDU 5904 LCIS DP
    Ubuntu上的android sdk提示 bash: ......sdk/platform-tools/adb或者emulator: 没有那个文件或目录 解决笔记
    重学数据结构系列之——平衡树之SB Tree(Size Blanced Tree)
    重学数据结构系列之——二叉排序树
    重学数据结构系列之——二叉树基础
    重学数据结构系列之——哈希表
    如何判断出栈序列合理性
    重学数据结构系列之——栈
  • 原文地址:https://www.cnblogs.com/xzybk/p/11791513.html
Copyright © 2011-2022 走看看