当前位置: 首页 > news >正文

Web 后台项目,权限如何定义、设置、使用:菜单权限、按钮权限 ts element-ui-Plus

Web 后台项目,权限如何定义、设置、使用:菜单权限、按钮权限 ts element-ui-Plus

做一个后台管理项目,里面需要用到权限管理。这里说一下权限定义的大概,代码不多,主要讲原理和如何实现它。

一、权限管理的原理

权限管理分三个部分:

  1. 接口的访问权限:
    这个后台去做就好了,前边只需要配置。
  2. 菜单的访问权限,展示给特定用户的菜单是哪样的
    这个需要前端设置,后台再返给你过滤后的菜单。
  3. 界面中的一些操作按钮
    这个是跟菜单走的,需要前端在界面的每个操作按钮上添加 v-if 判断,这里的权限就是个字符串。一个自定义的表示的字符串,用户有这个字符串就显示,没有就不显示。

这些权限是定义在角色上的,再给用户分配一些特定的角色即可。

在这里插入图片描述

二、实现

1. 接口权限

后端去实现,前端只需要提示可设置的操作流程即可

这里可以用 el-transfer 插件进行操作,会比较方便

在这里插入图片描述

2. 菜单权限

菜单权限只需要编辑哪些菜单可见就行。

在这里插入图片描述

3. 按钮权限

按钮权限是这里面比较麻烦的,但也不是很麻烦。
首先你需要在菜单定义中添加这个按钮,并添加这个按钮的权限标识,
比如 user:btn:add 表示 User 列表中的添加按钮,这个标识你可以随心定义,尽可能的简单且表义。
在这里插入图片描述

用户组设置菜单权限的时候也同步设置按钮权限

在这里插入图片描述

在页面中判断按钮是不是显示:

  1. 从登录后的菜单列表中获取所有的标识字符串列表,制作成 set 好供后面使用。
/*** 递归获取所有菜单权限* @param menuTree* @return Array<string>*/
function getPermissionArrayFromMenuTree(menuTree: Array<MenuEntity>): Array<string>{let tempPermissionArray: Array<string> = []menuTree.forEach(item => {if (item.children?.length > 0){tempPermissionArray = tempPermissionArray.concat( getPermissionArrayFromMenuTree(item.children))} else {if (item.perm) tempPermissionArray.push(item.perm)}})return tempPermissionArray
}// 通过上面的方法获取到所有权限数组后,把它弄成 set,放到 store 中供后续使用
// 这个操作一般在登录后,或者在页面刷新后
storeProject.permissionSet = new Set(getPermissionArrayFromMenuTree(res))
  1. 定义一个 enum 方便后续进行判断
    将所有在菜单中设置的权限字符串都设置成:文字-权限字符串Enum
    在这里插入图片描述

  2. 页面中使用权限判断这个按钮该不该显示

<el-buttonv-if="storeProject.permissionSet.has(EnumPermissions['员工:按钮:添加'])"type="success" icon="Plus" @click="addUser()">添加</el-button>

这样就能看到上面定义成 enum 的好处了,你不需要记那些权限标识。
在这里插入图片描述

三、完成

http://www.lryc.cn/news/334375.html

相关文章:

  • ADB 操作命令及其详细用法
  • 类的函数成员(三):拷贝构造函数
  • C#操作MySQL从入门到精通(8)——对查询数据进行高级过滤
  • Centos 7 安装通过yum安装google浏览器
  • 题目:学习使用按位与 。
  • 逐步分解,一文教会你如何用 jenkins+docker 实现主从模式
  • WebSocket 对于手游的意义
  • 安卓APP的技术质量:如何提高
  • 二分查找 -- 力扣(LeetCode)第704题
  • Windows下如何确定虚函数在虚函数表中的位置
  • C++设计模式:观察者模式(三)
  • CentOS运行Py脚本报错illegal instruction故障处理
  • 软件设计师——1.备考提纲
  • [开源] 基于GRU的时间序列预测模型python代码
  • SQL SERVER 备份
  • 提示词专场:从调整提示改善与LLMs的沟通,到利用LLMs优化提示效果
  • 测开面经(pytest测试案例,接口断言,多并发断言)
  • Golang 开发实战day09 - package Scope
  • 24考研-东南大学916经验贴
  • 【AI面试】YOLO 如何通过 k-means 得到 anchor boxes的?Yolo、SSD 和 faster rcnn 的正负样本定义
  • MySQL高级篇(B-Tree、Btree)
  • Zookeeper脑裂解决方案
  • 常用日常脚本
  • Longan Pi 3H 开发板体验
  • SpringCloud Alibaba Sentinel 创建流控规则
  • Mysql底层原理五:如何设计、用好索引
  • python学习杂记
  • C# Socket发送、接收结构体
  • ics-05-攻防世界
  • Web API(三)之事件流事件委托其他事件