Vue中router的beforeEach与afterEach钩子函数

版权声明:本文为博主原创文章,未经博主允许不得转载 https://blog.csdn.net/AiHuanhuan110/article/details/89158455

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

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

总的来说Vue提供了三大类钩子,和两种函数。

三大类钩子:

  1. 全局钩子
  2. 某个路由的钩子
  3. 组件内钩子

两种函数:

  1. Vue.beforeEach( function ( to, form, next) { } ) //在跳转之前执行
  2. Vue.afterEach( function ( to, form) ) //在跳转之后判断

全局钩子函数

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

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 平级的。

扫描二维码关注公众号,回复: 6044981 查看本文章
beforeRouteLeave(to, from, next) {
    next()
},
beforeRouteEnter(to, from, next) {
    next()
},
beforeRouteUpdate(to, from, next) {
    next()
},
data:{},
method: {}

猜你喜欢

转载自blog.csdn.net/AiHuanhuan110/article/details/89158455