vue中的路由守卫

路由守卫

  1. 作用:对路由进行权限控制
  2. 分类:全局守卫、独享守卫、组件内守卫

全局守卫

const router = new VueRouter({
  routes: [
    {
      path: '/home',
      component: Home,
      meta: { isAuth: false },	// 不需要进行权限控制
    },
     {
      path: '/user',
      component: User,
      meta: { isAuth: true },	// 需要进行权限控制
    },
  ]
})
// 全局前置守卫:初始化时执行/每次路由切换前执行
router.beforeEach((to,from,next) => {
  if(to.meta.isAuth) {  // 判断当前路由是否需要进行权限控制(在需要进行权限控制的路由中配置isAuth属性)
    if(localStorage.getItem('xxx') === 'xxx') { // 权限控制的具体规则
      next();   // 放行
    }else {
      ...
    }
  } else {  // 当前路由不需要进行权限控制
    next(); // 直接放行
  }
})
// 全局后置守卫:初始化时执行,每次路由切换后执行
router.afterEach((to,from) => {
  if(to.meta.title) {
    document.title = to.meta.title; // 修改网页的title
  }else {
    document.title = 'xxx';
  }
})

独享守卫

加在某个路由的配置中

beforeEnter((to,from,next) => {
  if(to.meta.isAuth) {  // 判断当前路由是否需要进行权限控制(在需要进行权限控制的路由中配置isAuth属性)
    if(localStorage.getItem('xxx') === 'xxx') { // 权限控制的具体规则
      next();   // 放行
    }else {
      ...
    }
  } else {  // 当前路由不需要进行权限控制
    next(); // 直接放行
  }
})

组件内守卫

// 进入守卫,通过路由规则,进入该组件时被调用
beforeRouteEnter(to,from,next){
  ...
}
// 当前路由改变,但是该组件被复用时调用
// 举例来说,对于一个带有动态参数的路径 /foo/:id,在 /foo/1 和 /foo/2 之间跳转的时候,
// 由于会渲染同样的 Foo 组件,组件实例会被复用。而这个钩子就会被调用
beforeRouteUpdate(to,from,next{
  ...
}
// 离开守卫,通过路由规则,离开该组件时被调用
beforeRouteLeave(to,from,next){
  ...
}
上一篇:元编程 (meta-programming)


下一篇:HTTP学习笔记