关于Vue-router中的beforeEach()

本文详细介绍了Vue-router的全局前置守卫beforeEach的使用,包括参数解析、next方法的应用及其注意事项,特别是next与next('/login')的区别,以及在用户登录验证场景中的实践。文中还指出在特定情况下如何避免死循环的问题。
摘要由CSDN通过智能技术生成

Vue-router中的beforeEach

全局前置守卫

我们可以通过router.beforeEach()来注册一个全局前置守卫:

const router = new VueRouter({
    ... })

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

里面的参数解析:

  • to: Route: 即将要进入的目标 路由对象
  • from: Route: 当前导航正要离开的路由
  • next: 调用 next()方法才能进入下一个路由,否则的如果写了beforeEach方法,但是没有调用next()方法的话,页面会空白,不会跳转到任何页面的。默认不写 router.beforeEach((to, from, next) => {}) 的话,它是默认跳转到指定页面去的,当然如果重写这个方法的话,会覆盖默认的方法。因此如果写了调用了该方法的话,一定需要调用 next()

对于next()里面是可以传入参数的,具体可以看看官网。
这个地方讲一讲next()与next(’/login’)
区别就是前者不会再次调用router.beforeEach(),后者会重新调用一次beforeEach()*(这个地方很关键,因为很容易出现死循环)

实例应用场景:
当验证一个用户是否登录的时候可以使用
代码:

router.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值