关于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 相关文章推荐
jqTransform form表单美化插件使用方法
Jul 05 Javascript
js将iframe中控件的值传到主页面控件中的实现方法
Mar 11 Javascript
JS打开层/关闭层/移动层动画效果的实例代码
May 11 Javascript
理解JavaScript中worker事件api
Dec 25 Javascript
Bootstrap Modal遮罩弹出层(完整版)
Nov 21 Javascript
bootstrap table 表格中增加下拉菜单末行出现滚动条的快速解决方法
Jan 05 Javascript
jquery对象与DOM对象转化
Feb 08 Javascript
浅谈struts1 & jquery form 文件异步上传
May 25 jQuery
vue 计时器组件的实现代码
Sep 14 Javascript
JS正则表达式完美实现身份证校验功能
Oct 18 Javascript
vue实现文件上传功能
Aug 13 Javascript
前端路由&webpack基础配置详解
Jun 10 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显示今天、今月、上月、今年的起点/终点时间戳的代码
2011/05/25 PHP
解析PHP函数array_flip()在重复数组元素删除中的作用
2013/06/27 PHP
PHP文件上传类实例详解
2016/04/08 PHP
javascript 写的一个简单的timer
2009/07/30 Javascript
下载站控制介绍字数显示的脚本 显示全部 隐藏介绍等功能
2009/09/19 Javascript
简单的JavaScript互斥锁分享
2014/02/02 Javascript
jQuery动画效果animate和scrollTop结合使用实例
2014/04/02 Javascript
Javascript中的异步编程规范Promises/A详细介绍
2014/06/06 Javascript
javascript实现在下拉列表中显示多级树形菜单的方法
2015/08/12 Javascript
Vue-Router实现页面正在加载特效方法示例
2017/02/12 Javascript
详解node如何让一个端口同时支持https与http
2017/07/04 Javascript
vue + typescript + 极验登录验证的实现方法
2019/06/27 Javascript
CountUp.js数字滚动插件使用方法详解
2019/10/17 Javascript
vuejs中父子组件之间通信方法实例详解
2020/01/17 Javascript
2020淘宝618理想生活列车自动领喵币js脚本的代码
2020/06/02 Javascript
Vue实现简易购物车页面
2020/12/30 Vue.js
[43:18]NB vs Infamous 2019国际邀请赛淘汰赛 败者组 BO3 第一场 8.22
2019/09/05 DOTA
PyMongo安装使用笔记
2015/04/27 Python
python编程开发之类型转换convert实例分析
2015/11/13 Python
python实现获取Ip归属地等信息
2016/08/27 Python
python DataFrame 取差集实例
2019/01/30 Python
Python3.5文件修改操作实例分析
2019/05/01 Python
Flask框架学习笔记之表单基础介绍与表单提交方式
2019/08/12 Python
Python实现生成密码字典的方法示例
2019/09/02 Python
Python通过TensorFLow进行线性模型训练原理与实现方法详解
2020/01/15 Python
Python 通过爬虫实现GitHub网页的模拟登录的示例代码
2020/08/17 Python
python中Array和DataFrame相互转换的实例讲解
2021/02/03 Python
Python中Qslider控件实操详解
2021/02/20 Python
详解CSS3弹性伸缩盒
2020/09/21 HTML / CSS
全球领先美式家具品牌:Ashley爱室丽家居
2017/08/07 全球购物
学校四群教育实施方案
2014/06/12 职场文书
房地产资料员岗位职责
2014/07/02 职场文书
师德先进个人事迹材料
2014/12/19 职场文书
秋季运动会开幕词
2015/01/28 职场文书
自考生自我评价
2019/06/21 职场文书
Vue的列表之渲染,排序,过滤详解
2022/02/24 Vue.js