关于Vue的路由权限管理的示例代码


Posted in Javascript onMarch 06, 2018

前言

曾经在工作上对 vue 路由权限管理这方面有过研究,这几天又看到了几篇相关的文章,再加上昨天电面中又再一次提及到,就索性整理了一下自己的一些看法,希望对大家有帮助。

实现

大体上实现的思路很简单,先上图:

关于Vue的路由权限管理的示例代码

无非是将路由配置按用户类型分割为 用户路由 和 基本路由,不同的用户类型可能存在不同的 用户路由,具体依赖实际业务。

  1. 用户路由: 当前用户所特有的路由
  2. 基本路由:所有用户均可以访问的路由

实现控制的方式分两种:

通过vue-router addRoutes 方法注入路由实现控制
通过vue-router beforeEach 钩子限制路由跳转

addRoutes 方式:

通过请求服务端获取当前用户路由配置,编码为 vue-router 所支持的基本格式(具体如何编码取决于前后端协商好的数据格式),通过调用 this.$router.addRoutes 方法将编码好的用户路由注入到现有的 vue-router 实例中去,以实现用户路由。

beforeEach 方式

通过请求服务端获取当前用户路由配置,通过注册 router.beforeEach 钩子对路由的每次跳转进行管理,每次跳转都进行检查,如果目标路由不存再于 基本路由 和 当前用户的 用户路由 中,取消跳转,转为跳转错误页。

以上两种方式均需要在 vue-router 中配置错误页,以保证用户感知权限不足。

两种方式的原理其实都是一样的,只不过 addRoutes 方式 通过注入路由配置告诉 vue-router :“当前我们就只有这些路由,其它路由地址我们一概不认”,而 beforeEach 则更多的是依赖我们手动去帮 vue-router 辨别什么页面可以去,什么页面不可以去。说白了也就是 自动 与 手动 的差别。说到这,估计大家都会觉得既然是 自动 的,那肯定是 addRoutes 最方便快捷了,还能简化业务代码,笔者一开始也是这么认为的,但是!很多人都忽略了一点:

关于Vue的路由权限管理的示例代码

addRoutes 方法仅仅是帮你注入新的路由,并没有帮你剔除其它路由!

设想存在这么一种情况:用户在自己电脑上登录了管理员账号,这个时候会向路由中注入管理员的路由,然后再退出登录,保持页面不刷新,改用普通用户账号进行登录,这个时候又会向路由中注入普通用户的路由,那么,在路由中将存在两种用户类型的路由,即使用户不感知,通过改变 url,普通用户也可以访问管理员的页面!

对于这个问题,也有一个解决办法:

import Vue from 'vue'
import Router from 'vue-router'
Vue.use(Router)
const createRouter = () => new Router({
 mode: 'history',
 routes: []
})
const router = createRouter()
export function resetRouter () {
 const newRouter = createRouter()
 router.matcher = newRouter.matcher
}
export default router

通过新建一个全新的 Router,然后将新的 Router.matcher 赋给当前页面的管理 Router,以达到更新路由配置的目的。

笔者做了一个小demo,大家可以去体验一下。

关于上述问题,在vue-router 的 github issues 下有过讨论,分别是:

Add option to Reset/Delete Routes #1436

Feature request: replace routes dynamically #1234

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Javascript中判断变量是数组还是对象(array还是object)
Aug 14 Javascript
JavaScript动态创建div属性和样式示例代码
Oct 09 Javascript
JS兼容浏览器的导出Excel(CSV)文件的方法
May 03 Javascript
一款基jquery超炫的动画导航菜单可响应单击事件
Nov 02 Javascript
jQuery同步提交示例代码
Dec 12 Javascript
浅谈JavaScript 中有关时间对象的方法
Aug 15 Javascript
ThinkPHP+jquery实现“加载更多”功能代码
Mar 11 Javascript
详解Chart.js轻量级图表库的使用经验
May 22 Javascript
vue中过滤器filter的讲解
Jan 21 Javascript
JavaScript函数式编程(Functional Programming)纯函数用法分析
May 22 Javascript
es6中比较有用的7个技巧小结
Jul 12 Javascript
uniapp开发打包多端应用完整方法指南
Dec 24 Javascript
vue.js在标签属性中插入变量参数的方法
Mar 06 #Javascript
基于Vue中点击组件外关闭组件的实现方法
Mar 06 #Javascript
解决vue build打包之后首页白屏的问题
Mar 06 #Javascript
vue2.0 路由不显示router-view的解决方法
Mar 06 #Javascript
解决vue-router进行build无法正常显示路由页面的问题
Mar 06 #Javascript
解决vue打包项目后刷新404的问题
Mar 06 #Javascript
写一个移动端惯性滑动&回弹Vue导航栏组件 ly-tab
Mar 06 #Javascript
You might like
php版阿里云OSS图片上传类详解
2016/12/01 PHP
PHP调用全国天气预报数据接口查询天气示例
2019/02/20 PHP
2020最新版 PhpStudy V8.1版本下载安装使用详解
2020/10/30 PHP
js常见表单应用技巧
2008/01/09 Javascript
7个Javascript地图脚本整理
2009/10/20 Javascript
javascript强大的日期函数代码分享
2013/09/04 Javascript
JavaScript也谈内存优化
2014/06/06 Javascript
new Date()问题在ie8下面的处理方法
2014/07/31 Javascript
jQuery超酷平面式时钟效果代码分享
2020/03/30 Javascript
原生js实现数字字母混合验证码的简单实例
2015/12/10 Javascript
详解redis在nodejs中的应用
2018/05/02 NodeJs
vue mounted组件的使用
2018/06/18 Javascript
Vue.js实现数据响应的方法
2018/08/13 Javascript
详解IOS微信上Vue单页面应用JSSDK签名失败解决方案
2018/11/14 Javascript
vue 集成 vis-network 实现网络拓扑图的方法
2019/08/07 Javascript
VScode格式化ESlint方法(最全最好用方法)
2019/09/10 Javascript
python实现简单的计时器功能函数
2015/03/14 Python
Python中字典的基础知识归纳小结
2015/08/19 Python
Python使用SocketServer模块编写基本服务器程序的教程
2016/07/12 Python
简单了解python模块概念
2018/01/11 Python
python3获取当前文件的上一级目录实例
2018/04/26 Python
利用pyinstaller将py文件打包为exe的方法
2018/05/14 Python
解决Python中list里的中文输出到html模板里的问题
2018/12/17 Python
Python 获取ftp服务器文件时间的方法
2019/07/02 Python
Python+OpenCV+图片旋转并用原底色填充新四角的例子
2019/12/12 Python
基于python检查SSL证书到期情况代码实例
2020/04/04 Python
pycharm下pyqt4安装及环境配置的教程
2020/04/24 Python
Python自动化操作实现图例绘制
2020/07/09 Python
pandas 按日期范围筛选数据的实现
2021/02/20 Python
澳大利亚顶级美发和美容贸易超市:glamaCo
2020/01/19 全球购物
武汉世纪畅想数字传播有限公司 .NET笔试题
2015/06/13 面试题
生物学学生自我评价
2014/01/17 职场文书
单位个人查摆问题及整改措施
2014/10/28 职场文书
Windows下redis下载、redis安装及使用教程
2021/06/02 Redis
从QQtabBar看css命名规范BEM的详细介绍
2021/08/07 HTML / CSS
利用Python将list列表写入文件并读取的方法汇总
2022/03/25 Python