vue router导航守卫(router.beforeEach())的使用详解


Posted in Javascript onApril 19, 2019

导航守卫

        导航守卫主要用来通过跳转或取消的方式守卫导航。有多种机会植入路由导航过程中:全局的, 单个路由独享的, 或者组件级的。(记住参数或查询的改变并不会触发进入/离开的导航守卫。你可以通过观察$route对象来应对这些变化,或使用beforeRouteUpdate的组件内守卫。)

好久没写一些东西了,总是感觉有啥缺少的。~~~~恰好碰到最近在写一个移动端项目,遇到了如何使同一个链接在不同条件下跳转到不同路由组件问题,譬如大家经常看到手机中没登录跳转登录页,登陆后跳转个人信息页等。废话不多说了,直接上图:

vue router导航守卫(router.beforeEach())的使用详解

这是没登录状态,点击下面mine按钮跳转至登录页

vue router导航守卫(router.beforeEach())的使用详解

这个是我登录了自己的账号后,再次点击mine按钮会跳转至个人信息页面

好了,看到了这个效果今天咱们来实现下

实现方法

我们点击下面mine按钮其实是路由跳转,所以我们需要在跳转路由之前做一个判断,根据不同的条件让这个链接跳转到不同路由。这时候我们vue-router中的导航守卫就闪亮登场了~~~

先看官方文档: https://router.vuejs.org/zh-cn/advanced/navigation-guards.html

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

官方文档中说了很清楚,我们可以使用 router.beforeEach 注册一个全局前置守卫:

在router文件夹下index.js中添加以下代码

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

vue router导航守卫(router.beforeEach())的使用详解

这里对router.beforeEach方法的每个参数做简要的解释。

“to”: 即将要进入的目标 路由对象;(这个对象中包含name,params,meta等属性)

"from": 当前导航正要离开的路由对象;(这个对象中包含name,params,meta等属性)

“next”: Function: 确保要调用 next 方法,否则钩子就不会被 resolved。这个当中还可以传一些参数,具体可以看官方文档。

我们在代码中做了一个判断 if (to.name === 'Mine') ,也就是说当我们要跳转的路由对象是Mine时候,才会进入导航守卫中判断条件,当我们点击其他链接跳转其他页正常,因为我们只有mine按钮链接对应的情况有两种。

// 登陆/注册就去用户详情页
 if (localStorage.getItem('userID')) {
  router.replace('/myinfo')
 }

这段代码就是判断当用户点击了mine,我们需要判断用户是否是登录还是未登录了。因为之前用户登录的时候我将用户的userID保存到了localStorage中,所以只需要判断localStorage中是否有用户的userID,来判断用户是否登录。这里情况两个,未登录去登录页,登录去个人信息页

好了,通过简单的配置使用,我们就可以愉快的根据不同的情况来实现路由跳转不同组件了~

哈哈,很简单吧,欢迎大家一起交流学习前端知识。我在GitHub上等你一起呦
~

说明

文章因为是在工作之余写的,可能时间匆忙,有些错别字或者语法等低级错误,欢迎留言指出,谢谢。。

同时在GitHub上也可以一起交流交流~~~

GitHub 走你

总结

以上所述是小编给大家介绍的vue router导航守卫(router.beforeEach())的使用详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
JQuery插件Style定制化方法的分析与比较
May 03 Javascript
禁止你的左键复制实用技巧
Jan 04 Javascript
ScrollDown的基本操作示例
Jun 09 Javascript
JavaScript严格模式详解
Nov 18 Javascript
JS面试题---关于算法台阶的问题
Jul 26 Javascript
利用yarn实现一个webpack+react种子
Oct 25 Javascript
vue使用vue-cli快速创建工程
Jul 28 Javascript
AngularJS实现的获取焦点及失去焦点时的表单验证功能示例
Oct 25 Javascript
微信小程序实现添加手机联系人功能示例
Nov 30 Javascript
详解vuex commit保存数据技巧
Dec 25 Javascript
vuex实现像调用模板方法一样调用Mutations方法
Nov 06 Javascript
vue中 v-for循环的用法详解
Feb 19 Javascript
this.$toast() 了解一下?
Apr 18 #Javascript
Vue-input框checkbox强制刷新问题
Apr 18 #Javascript
vue axios封装及API统一管理的方法
Apr 18 #Javascript
Vue组件系列开发之模态框
Apr 18 #Javascript
详解vue的数据劫持以及操作数组的坑
Apr 18 #Javascript
微信小程序 setData 对 data数据影响问题
Apr 18 #Javascript
详解JavaScript中关于this指向的4种情况
Apr 18 #Javascript
You might like
PHP和Mysql中转UTF8编码问题汇总
2015/10/10 PHP
php+Ajax无刷新验证用户名操作实例详解
2019/03/04 PHP
jQuery 中关于CSS操作部分使用说明
2007/06/10 Javascript
精心挑选的12款优秀的基于jQuery的手风琴效果插件和教程
2012/08/22 Javascript
JavaScript移除数组元素减少长度的方法
2013/09/05 Javascript
JQuery记住用户名密码实现下次自动登录功能
2015/04/27 Javascript
基于javascript实现九九乘法表
2016/03/27 Javascript
详解微信小程序 页面跳转 传递参数
2016/12/08 Javascript
js实现移动端微信页面禁止字体放大
2017/02/16 Javascript
原生JS中slice()方法和splice()区别
2017/03/06 Javascript
详解React Native网络请求fetch简单封装
2017/08/10 Javascript
Angularjs中ng-repeat的简单实例
2017/08/25 Javascript
vue仿淘宝订单状态的tab切换效果
2020/06/23 Javascript
vue页面切换到滚动页面显示顶部的实例
2018/03/13 Javascript
bootstrap中的导航条实例代码详解
2019/05/20 Javascript
VUE UPLOAD 通过ACTION返回上传结果操作
2020/09/07 Javascript
[01:02:38]DOTA2-DPC中国联赛定级赛 LBZS vs Phoenix BO3第二场 1月10日
2021/03/11 DOTA
浅谈Python浅拷贝、深拷贝及引用机制
2016/12/15 Python
解决python3 pika之连接断开的问题
2018/12/18 Python
python3利用ctypes传入一个字符串类型的列表方法
2019/02/12 Python
python tkinter canvas 显示图片的示例
2019/06/13 Python
Python 实现集合Set的示例
2020/12/21 Python
python实现发送QQ邮件(可加附件)
2020/12/23 Python
python中lower函数实现方法及用法讲解
2020/12/23 Python
CSS实现鼠标滑过鼠标点击代码写法
2016/12/26 HTML / CSS
html5实现多文件的上传示例代码
2014/02/13 HTML / CSS
基于canvas的骨骼动画的示例代码
2018/06/12 HTML / CSS
幼儿园元旦亲子活动方案
2014/02/17 职场文书
电焊工岗位职责
2014/03/06 职场文书
自愿离婚协议书范文2014
2014/10/12 职场文书
2015年员工试用期工作总结
2014/12/12 职场文书
学习雷锋精神活动总结
2015/02/06 职场文书
六五普法学习心得体会
2016/01/21 职场文书
php 获取音视频时长,PHP 利用getid3 获取音频文件时长等数据
2021/04/01 PHP
Vue CLI中模式与环境变量的深入详解
2021/05/30 Vue.js
详解JAVA的控制语句
2021/11/11 Java/Android