详解vue-router中的导航钩子

一:概念

作用:拦截导航,让他完成跳转或取消。

const router = new VueRouter({ ... });
router.beforeEach((to, from, next) => {
    // do someting
});

 

  • to: 要进入的目标,路由对象
  • from: 要离开的路由,路由对象
  • next: 一个必须需要调用的方法,而具体的执行效果则依赖 next 方法调用的参数

 

  • next():如果一切正常,则调用这个方法进入下一个钩子,导航钩子结束。
  • next(false):取消导航(即路由不发生改变)。
  • next('/login'):当前的导航被中断,然后进行一个新的导航(路径可自由指定)。
  • next(error):如果一个 Error 实例,则导航会被终止且该错误会被传递给 router.onError() 注册过的回调。

 2:常用场景

  • 比如某些页面需要先验证是否登录,如果登录了就可以访问,否则跳转到登录页。

//全局路由改变前钩子

router.beforeEach((to, from, next) => {

  //这里简单地使用localStorage来判断是否登陆

  if(window.localStorage.getItem('token')){

    next();

  }else{

    next('/login');

  }

})

3: 可替代的方法---》使用 watch 监测路由变化

<template>

  <div id="app">

      <keep-alive>

        <router-view/>

      </keep-alive>

  </div>

</template>



<script>

export default {

  name: 'App',

  watch: {

    '$route' (to, from) {

      // 对路由变化作出响应...

    }

  }

}

</script>

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值