理解、使用 beforeRouteEnter 前置守卫

2 篇文章 0 订阅

前置守卫(路由守卫/导航守卫):

  • 怎么理解?
    就像在组件前面守卫的士兵一样,满足条件才能访问组件。
    举个例子,比如在没登陆之前不能进入个人中心。
  • 咋实现的?
    请求getUser接口,获取里面的状态值status,如果是0,说明登录过了,不是0,没登陆,直接next到登录页面去。
beforeRouteEnter(to,from,next){
    axios.get('/api2/users/getUser').then((res)=>{
        var status=res.data.status;
        if(status === 0){
            next(vm=>{
                vm.$store.commit('user/USER_NAME',{name:res.data.data.username});
            });
        }else{
            next('/mine/login');
        }
    });
}

to:去哪里
form:来自于哪里
next:向下执行,如果不调用next就不往下走了,如果调用next就继续往下走下面的流程。

  • 什么时候调用?
    只要to和from代表的组件不一样就会调用。

注意:这个方法不能获取到this,因为守卫在导航确认前被调用,因此即将登场的新组件还没被创建。
不过,你可以通过传一个回调给 next来访问组件实例。在导航被确认的时候执行回调,并且把组件实例作为回调方法的参数。
像这样:

beforeRouteEnter (to, from, next) {
  next(vm => {
    // 通过 `vm` 访问组件实例
  })

更加详细的说明可以查看官方文档:官方文档

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值