Vue守卫

全局导航守卫
  • 是在做权限验证的时候会使用导航守卫
    。1.前置守卫
//单独设置每个路由的属性:
meta: { may: true }
router.beforeEach((to, from, next) => {
    if (to.matched.some(item => item.meta.may)) {
        let id = window.localStorage.getItem("id")
        if (id) {
            next()
        } else {
            next({ name: "login" })
        }
    } else {
        next()
    }
})

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

  • 后置钩子函数
router.afterEach((to,from) => {
	if(to.meta && to.meta.title){
		document.title = to.meta.title
	}else{
		document.title = "666"
	}
})
组件内守卫
// 不能获取组件实例 `this`
// 因为当守卫执行前,组件实例还没被创建
//写在组件里面
*** beforeRouteEnter(to,from,next){
 if(to.params.id<10) //如果数据里面的id小于10就表示有,就进入页面
    next() 登录
}else{
    next("/home")  返回首页
 }
}beforeRouteUpdate (to, from, next) {
// 在当前路由改变,但是该组件被复用时触发
// 可以访问组件实例 `this`
     next() 只要改变触发就执行next()
 },
 
 beforeRouteLeave (to, from, next) {
   // 导航离开该组件的对应路由时调用
   // 可以访问组件实例 `this`
     next()
 }
//to是要到哪里去
 from是要从哪里来
 next就是成功就执行
路由独享守卫
const router = new VueRouter({
  routes: [
    {
      path: '/foo',
      name:"foo"
      component: Foo,
      
      //它是在配置路由文件里面写 router/index.js
      beforeEnter: (to, from, next) => {
        // 只守卫当前的一条路由
      }
    }
  ]
})
全局守卫
  • router.beforeResolve 注册一个全局守卫,和 router.beforeEach 类似
	const router = new VueRouter({ 
	  //里面是路由路径
   })
   const login=["order","my"]   //数组里面是要判断的路由的权限
   router.beforeEach((to,from,next)=>{
     if(login.includes(to.name)){  //权限     
     let userId=window.localStroage.getItem("userId") //只能存字符串
      if(userId){  //登录
        next()
          }else{  //没有登录
            next("/login")
          }
     }else
        next()
  })
   export default router;
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值