vue开发:组件内的导航守卫

故事背景
面试但凡问到vue框架,vue-router是逃不掉的~
vue为我们提供了全局守卫、路由独享的守卫、组件内的守卫,详情戳这vue导航守卫
卤煮借项目里实际的应用场景来讲一下组件内的导航守卫,顺便记录一下小坑~

应用场景
当页面返回上一页的时候,拦截路由,提示用户是否确定离开当前页面,上图~

代码实现
组件内的导航守卫:beforeRouteEnter和beforeRouteLeave两个钩子函数,拦截跳转用到的是beforeRouteLeave,上图~
在这里插入图片描述
这里有个小坑,因为return写习惯了,以为在前面写了return下面就不执行了,实则不然,next在这里执行了,正确的写法如下:
在这里插入图片描述
next()传入true执行跳转,传入false则实现拦截,留在当前页。它也可以接收一个对象,例如:

next({
	path: '/login', params: { // 你想传的参数 }
});

注意!!!
在页面A,用户点击了返回,提示框弹出并且用户点击了确定离开,然后成功返回上一页。当用户通过浏览器导航栏进行返回前进,此时我们组件实例中的isGoback(此时isGoback为true)不会发生改变,再次返回就不会弹出提示框了哦。所以最稳妥的解决方法就是在进入页面的时候重置一下这个变量,这时候就用到beforeRouteEnter这个钩子函数了~
那么问题来了,官方说beforeRouteEnter钩子里面是获取不到this的,这可怎么搞,上图~
在这里插入图片描述
以上利用组件内的导航守卫,完美解决了路由拦截,实现我们上面提到的应用场景,记得勿踩坑~

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值