vue 路由守卫和路由拦截器_Vue学习笔记之路由的导航守卫应用及技巧

路由的导航守卫:

概念:"导航"表示路由正在发生改变,导航守卫主要用来通过跳转或取消的方式守卫导航。

正如其名,vue-router 提供的导航守卫主要用来通过跳转或取消的方式守卫导航。有多种机会植入路由导航过程中:全局的, 单个路由独享的, 或者组件级的。

记住参数或查询的改变并不会触发进入/离开的导航守卫。你可以通过观察 $route 对象来应对这些变化,或使用 beforeRouteUpdate 的组件内守卫。

42c3669d6ef33a2ec7dfe55212723ee3.png

应用:每个守卫方法接收三个参数:

· to: Route: 即将要进入的目标路由对象

· from: Route: 当前导航正要离开的路由

· next: Function: 一定要调用该方法来 resolve 这个钩子。执行效果依赖 next 方法的调用参数

例如实现一个需求,网页的title根据不同的页面显示不同的内容,可以通过两个方式实现:

①通过vue的生命周期来实现:

· created():当组件被创建之后回调此函数

· mounted():将模板内容挂载到页面上的时候回调此函数

· updated():在界面发生更新(刷新)的后会回调此函数

第一个方法就是通过created生命周期函数来实现此需求:

59c5d3f9c455c5e87f77a5f764e1e492.png

点击其他按钮,则变更为其他对应的名称:

ccc5a317a9027ed400011ac4914c4bb8.png

但是此方法比较麻烦,因为他需要在每个vue文件里面进行添加此代码,在后期维护或修改的时候,非常不方便,所以一般此需求可以通过在路由配置里面去实现。

②通过路由的全局导航守卫:router.beforeEach函数来实现(前置守卫guard-->回调)

295821ea278e37f3c295721714c7342d.png

PS:这里重写了前置守卫(beforeEach)函数,记得next()一定要加上,要不然页面跳转就无效了

其中:meta是元数据,描述数据的数据,通过元数据来获取相关的内容:

e43e2d9e03d0daf55da8a427a1dc8390.png

这个元数据也存在于matched数组中:

f89006c9c2799b534dde620f2ec90e00.png

document.title = to.matched[0].meta.title

8c9cebdb9d1882fb775c31fedc6ad0d6.png

③通过全局导航守卫:后置钩子hook(路由跳转完后的回调):afterEach,这个方法就不需要上面提到在重写函数中还要主动调用next()函数:

d8932301c78dd54c7d47d80059ef6567.png

PS:除了全局守卫,还有路由独享守卫,组件内的守卫,相关资料可以参考官网进行学习:https://router.vuejs.org/zh/guide/advanced/navigation-guards.html

· 全局守卫,官网介绍:

35b406481880a98295f8ebada59cb888.png

其中参数next()函数的应用:

da35ec05a56e5198a1e323a97d914caa.png

next()函数的案例:

c527559131336bedb0520005f3a11372.png

· 路由独享守卫:

6eb8f5548e2967f16cc4bfc913b8cf6c.png

官网介绍:

f391265a6c0d2f8382b21b94e9ebd0e1.png

· 组件内的守卫,官网介绍:

最后,你可以在路由组件内直接定义以下路由导航守卫:

1. beforeRouteEnter

2. beforeRouteUpdate (2.2 新增)

3. beforeRouteLeave

8f8abd67d907562ce808883ac2848545.png

beforeRouteEnter 守卫 不能 访问 this,因为守卫在导航确认前被调用,因此即将登场的新组件还没被创建。

不过,你可以通过传一个回调给 next来访问组件实例。在导航被确认的时候执行回调,并且把组件实例作为回调方法的参数。

3fffa24009174c6462d0470b559fff61.png

注意 beforeRouteEnter 是支持给 next 传递回调的唯一守卫。对于 beforeRouteUpdate 和 beforeRouteLeave 来说,this 已经可用了,所以不支持传递回调,因为没有必要了。

9c46cc5134583f420d15a5e7435d8c03.png

这个离开守卫通常用来禁止用户在还未保存修改前突然离开。该导航可以通过 next(false) 来取消。

7f8f627ecdac423b5f0f5708f7f62d96.png
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值