网站首页 > 博客文章 正文
路由的导航守卫:
概念:"导航"表示路由正在发生改变,导航守卫主要用来通过跳转或取消的方式守卫导航。
正如其名,vue-router 提供的导航守卫主要用来通过跳转或取消的方式守卫导航。有多种机会植入路由导航过程中:全局的, 单个路由独享的, 或者组件级的。
记住参数或查询的改变并不会触发进入/离开的导航守卫。你可以通过观察 $route 对象来应对这些变化,或使用 beforeRouteUpdate 的组件内守卫。
应用:每个守卫方法接收三个参数:
· to: Route: 即将要进入的目标路由对象
· from: Route: 当前导航正要离开的路由
· next: Function: 一定要调用该方法来 resolve 这个钩子。执行效果依赖 next 方法的调用参数
例如实现一个需求,网页的title根据不同的页面显示不同的内容,可以通过两个方式实现:
①通过vue的生命周期来实现:
· created():当组件被创建之后回调此函数
· mounted():将模板内容挂载到页面上的时候回调此函数
· updated():在界面发生更新(刷新)的后会回调此函数
第一个方法就是通过created生命周期函数来实现此需求:
点击其他按钮,则变更为其他对应的名称:
但是此方法比较麻烦,因为他需要在每个vue文件里面进行添加此代码,在后期维护或修改的时候,非常不方便,所以一般此需求可以通过在路由配置里面去实现。
②通过路由的全局导航守卫:router.beforeEach函数来实现(前置守卫guard-->回调)
PS:这里重写了前置守卫(beforeEach)函数,记得next()一定要加上,要不然页面跳转就无效了
其中:meta是元数据,描述数据的数据,通过元数据来获取相关的内容:
这个元数据也存在于matched数组中:
document.title = to.matched[0].meta.title
③通过全局导航守卫:后置钩子hook(路由跳转完后的回调):afterEach,这个方法就不需要上面提到在重写函数中还要主动调用next()函数:
PS:除了全局守卫,还有路由独享守卫,组件内的守卫,相关资料可以参考官网进行学习:https://router.vuejs.org/zh/guide/advanced/navigation-guards.html
· 全局守卫,官网介绍:
其中参数next()函数的应用:
next()函数的案例:
· 路由独享守卫:
官网介绍:
· 组件内的守卫,官网介绍:
最后,你可以在路由组件内直接定义以下路由导航守卫:
1. beforeRouteEnter
2. beforeRouteUpdate (2.2 新增)
3. beforeRouteLeave
beforeRouteEnter 守卫 不能 访问 this,因为守卫在导航确认前被调用,因此即将登场的新组件还没被创建。
不过,你可以通过传一个回调给 next来访问组件实例。在导航被确认的时候执行回调,并且把组件实例作为回调方法的参数。
注意 beforeRouteEnter 是支持给 next 传递回调的唯一守卫。对于 beforeRouteUpdate 和 beforeRouteLeave 来说,this 已经可用了,所以不支持传递回调,因为没有必要了。
这个离开守卫通常用来禁止用户在还未保存修改前突然离开。该导航可以通过 next(false) 来取消。
猜你喜欢
- 2024-10-05 Web 开发中 route 和 router 有什么区别?
- 2024-10-05 图解各种路由协议(路由协议基础知识)
- 2024-10-05 「vue基础」一篇浅显易懂的 Vue 路由使用指南( Vue Router 下)
- 2024-10-05 2024前端面试题(三)(2020前端最新面试题)
- 2024-10-05 详解Vue3中 router 带来了哪些变化?
- 2024-10-05 Vue实战篇|使用路由管理用户权限(动态路由)
- 2024-10-05 vue路由鉴权(vue 路由鉴权)
- 2024-10-05 Vue Router中应对路由参数变动的策略(watch监听与导航守卫应用)
- 2024-10-05 前端权限路由详细介绍(前端路由权限控制)
- 2024-10-05 VUE前端编程:浅谈路由的常见管理模式
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- ifneq (61)
- 字符串长度在线 (61)
- googlecloud (64)
- messagesource (56)
- promise.race (63)
- 2019cad序列号和密钥激活码 (62)
- window.performance (66)
- qt删除文件夹 (72)
- mysqlcaching_sha2_password (64)
- ubuntu升级gcc (58)
- nacos启动失败 (64)
- ssh-add (70)
- jwt漏洞 (58)
- macos14下载 (58)
- yarnnode (62)
- abstractqueuedsynchronizer (64)
- source~/.bashrc没有那个文件或目录 (65)
- springboot整合activiti工作流 (70)
- jmeter插件下载 (61)
- 抓包分析 (60)
- idea创建mavenweb项目 (65)
- vue回到顶部 (57)
- qcombobox样式表 (68)
- tomcatundertow (58)
- pastemac (61)
本文暂时没有评论,来添加一个吧(●'◡'●)