【前端项目笔记】4 权限管理

权限管理

效果展示:
(1)权限列表
在这里插入图片描述
(2)角色列表
在这里插入图片描述
其中的分配权限功能
在这里插入图片描述

权限列表功能开发

新功能模块,需要创建新分支
git branch 查看所有分支(*表示当前分支)
git checkout -b rights 创建新分支rights并切换到该分支上
git push -u origin rights 把本地的rights分支推送到云端origin仓库进行保存分支名为rights

先创建对应的组件再创建对应的路由规则
在这里插入图片描述
在这里插入图片描述
结果展示
在这里插入图片描述

绘制权限列表的基本页面布局

面包屑导航+卡片视图(Table数据表格)
在这里插入图片描述

权限列表的数据获取

在这里插入图片描述

权限列表数据的表格渲染

在这里插入图片描述

角色列表功能开发

用户、角色、权限之间的关系

用户代表电商后台管理系统的每一个账号
权限代表账号所拥有的能力,对一个列表来说分为增删改查这些操作
角色代表不同用户拥有的不同权限
首先把权限分配给不同的角色,再把角色分配给对应的用户(把用户绑定了不同角色,每个角色下拥有不同权限)
在这里插入图片描述

角色列表路由切换

创建组件+创建对应路由规则
在这里插入图片描述
在这里插入图片描述

角色列表基础布局+获取角色列表相关数据

基础布局:
面包屑导航+卡片视图区域(添加角色按钮+Table列表)
在这里插入图片描述
获取角色列表数据
在这里插入图片描述

表格中角色列表数据的渲染

在这里插入图片描述
增删改查

添加角色:

  1. 点击按钮弹出添加角色的对话框并添加表单校验规则
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
  2. 添加角色表单关闭对话框后的重置
    在这里插入图片描述
  3. 添加角色前的表单预校验并实现真正的添加角色功能
    在这里插入图片描述在这里插入图片描述

修改角色:
4. 添加修改角色表单的内容并撰写对应验证规则
在这里插入图片描述
在这里插入图片描述
5. 展示修改角色的对话框
在这里插入图片描述
在这里插入图片描述
6. 修改表单后关闭对话框需要进行重置操作
在这里插入图片描述
7. 预校验及修改角色信息操作
在这里插入图片描述
在这里插入图片描述

删除角色:
8. 在删除角色之前先弹出提示是否确认删除的对话框(弹框MessageBox)
在这里插入图片描述
9. 判断是否确认删除,确认发送delete请求(通过id删除用户),取消返回提示信息
在这里插入图片描述

角色下权限数据的渲染

pre标签,主要用来渲染带有转义字符的(空格符和换行符等) 的文本内容(字符串)

  1. 通过作用域插槽拿到scope.row,通过scope.row拿到对应的角色信息
  2. 通过三层for循环把对应的权限渲染出来,每循环一次往tag里放标签
    通过scope.row.children拿到一级权限
    在这里插入图片描述
    在正常形态下,:span默认为24。假如:span为12,那么就是原本列数的一半。
    一级权限的美化:
    在这里插入图片描述
    在这里插入图片描述
    二级权限及三级权限:
    在这里插入图片描述
    将一级权限和二级权限纵向居中
    在这里插入图片描述
    在这里插入图片描述
    为展开项中每一个权限标签增加一个删除小图标并实现删除权限功能:
    在这里插入图片描述

为每个标签添加closable属性,可定义标签是否可移除
在这里插入图片描述
首先设置第三权限的删除操作:
在这里插入图片描述
**☆优化点:**解决删除权限后关闭展开项无法及时看到删除哪项权限的问题。由于delete请求返回的data, 是当前角色下最新的权限数据,故可用res.children = res.data 为当前角色重新赋值权限,避免当前页面的完整渲染,提升用户体验。
在这里插入图片描述
为第二权限、第一权限增加删除功能:
在这里插入图片描述

分配权限功能的实现

弹出对话框,以树形结构获取所有权限数据:
在这里插入图片描述在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在对话框中显示树形结构数据:
在这里插入图片描述
在这里插入图片描述
组件按需导入+全局注册:
在这里插入图片描述
树形控件基本展示:
在这里插入图片描述
进一步优化树形控件:

  1. 在每个节点前添加复选框show-checkbox
  2. 选中某节点时不能只是选中文本,要默认选中它的id值
    在这里插入图片描述3. 默认展开所有节点
    在这里插入图片描述
    在这里插入图片描述

已有权限在树上的默认勾选功能

在点按钮的同时,将当前角色的所有第三权限的id放到一个数组中,通过属性绑定将这个数组交给default-checked-keys
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
以递归的方式获取第三权限的id:
在这里插入图片描述
在showSetRightDialog函数中调用getLeafKeys函数
在这里插入图片描述
在这里插入图片描述
解决bug:
关闭分配权限对话框未清空之前的权限数据,导致后面角色的对话框包含之前的数据(每次点开不同角色的分配角色对话框,数据越来越多)
解决方法:每次关闭对话框清空defKeys数组
在这里插入图片描述
在这里插入图片描述

具体分配权限的功能

  1. 在点击“分配权限”按钮时,先立即把该角色的id保存到data中供后面发送请求使用
    在这里插入图片描述
    在这里插入图片描述

  2. 点击“确定”按钮时,把所有全选中节点的id和半选中节点的id合并成完整数组
    tree组件中获取全节点和半节点的id值以数组形式返回的两个函数
    在这里插入图片描述
    在这里插入图片描述
    JavaScript中的三个点(…)扩展运算符是一种简写语法,用于取出参数对象的所有可遍历属性,值的集合,展开为函数参数列表或数组。
    在这里插入图片描述

  3. 把这个数组拼接形成字符串(中间以’,'拼接)发送角色授权的请求
    在这里插入图片描述

提交代码到git仓库中

git branch 查看当前所处分支(当前分支是rights,前面打*号)
git add . 把所有修改过的代码添加到暂存区
git commit -m "完成了权限功能的开发" 把当前所有代码提交到rights分支
git push 把本地right分支提交到云端(不需要-u,因为云端已存在rights分支)
git checkout master 切换到主分支master
git merge rights 把rights分支代码合并到主分支master中
此时本地的master分支已经是最新的,云端中master还是旧的
git push 需要把本地master推送到云端(分支推一次,主线推一次)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/747252.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

机器学习辅助的乙醇浓度检测(毕设节选)

目录 1.为什么要机器学习 2. 神经网络一般组成 3.BP神经网络工作过程 4.评价指标 5.实操代码 1.为什么要用机器学习 人工分析大量的谐振模式,建立各种WGM的响应与未知目标之间的关系,是一个很大的挑战。机器学习(ML)能够自行识别全谱的全部特征。作为…

021.合并两个有序链表,递归和遍历

题意 将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 难度 简单 标签 链表、排序 示例 输入:l1 [1,2,4], l2 [1,3,4] 输出:[1,1,2,3,4,4]输入:l1 [], l2 [] 输出:[]…

Maven列出所有的依赖树

在 IntelliJ IDEA 中,你可以使用 Maven 插件来列出项目的依赖树。Maven 插件提供了一个名为dependency:tree的目标,可以帮助你获取项目的依赖树详细信息。 要列出项目的依赖树,可以执行以下步骤: 打开 IntelliJ IDEA,…

未来科技中的RTK接收机应用探索

RTK实时差分定位技术(RTK,Real-Time Kinematic),作为高精度定位技术的一种重要手段,已经在地理测绘、测量工程、航空航天等领域取得了广泛应用。随着科技的不断发展,RTK导航接收机的应用领域也日益拓宽。首…

文华wh6均线交易策略多空波段止盈止损提示主图指标公式源码

文华wh6均线交易策略多空波段止盈止损提示主图指标公式源码&#xff1a; EMA120:EMA(C,120); RSV:(CLOSE-LLV(LOW,9))/(HHV(HIGH,9)-LLV(LOW,9))*100; K:SMA(RSV,3,1); D:SMA(K,3,1); J:3*K-2*D; DRAWTEXT(C>EMA120&&J<0,L,多),VALIGN0; DRAWTEXT(C<EMA…

Blazor的SSR服务端渲染是不是交互式的

从.NET8开始&#xff0c;Blazor引入了SSR服务端渲染&#xff0c;归功于MVC和RazePage的沉淀&#xff0c;虽然来得晚&#xff0c;但一经发布&#xff0c;就将Blazor推向了新的高度。从今年开始&#xff0c;Youtube上关于Blazor的优质教学视频&#xff0c;以肉眼可见的速度在增加…

基于Java的门禁系统【附源码】

第1章 绪论 1.1 课题背景 门禁系统就是对出入口通道进行管制的系统&#xff0c;它是在传统的门锁基础上发展而来的。传统的机械门锁仅仅是单纯的机械装置&#xff0c;无论结构设计多么合理&#xff0c;材料多么坚固&#xff0c;人们总能通过各种手段把它打开。在出入人员很多的…

写程序100道41-50

41.定义一个Father和Child类&#xff0c;并进行测试。 要求如下&#xff1a; (1)Father类为外部类&#xff0c;类中定义一个私有的String类型的属性name&#xff0c;name的值为“Join”。 (2)Child类为Father类的内部类&#xff0c;其中定义一个readName()方法&#xff0c;方…

PHP 界的扛把子 Swoole 异步通信利器

大家好&#xff0c;我是码农先森。 引言 我今天主要介绍的内容是包括但不仅限于 Swoole &#xff0c;也有一部分 Go 语言的内容。 为什么要介绍 Swoole ? 先说一说背景吧&#xff0c;我们项目组之前要为《香港 01》开发一个积分系统的项目&#xff0c;这个系统的主要功能包…

LINUX centos 安装jenkins超超超超超超级详细步骤

Jenkins安装 配置jdkmavengit jenkins 拉取 配置 jdk 1.安装jdk8 yum install java-1.8.0-openjdk-devel2.检查版本 java -version出现如下图查看版本信息 3. 设置JAVA_HOME环境变量 vim /etc/profile最下方输入 export JAVA_HOME/usr/lib/jvm/java-1.8.0-openjdk expor…

鸿蒙开发HarmonyOS NEXT(一)

最近总听见大家讨论鸿蒙&#xff0c;前端转型的好方向&#xff1f;先入门学习下 目前官方版本和文档持续更新中 一、开发环境 提示&#xff1a;要占用的空间比较多&#xff0c;建议安装在剩余空间多的盘 1、下载&#xff1a;官网最新工具 - 下载中心 - 华为开发者联盟 (huaw…

记一次 APK 逆向动静调试 + so 动态链接库分析

0x00 前言&#xff1a; 好久没有做过安卓逆向了&#xff0c;最近重新系统地学习了安卓逆向技术。找到了一道较为典型的逆向分析题来练手&#xff0c;以锻炼动静态分析和动态链接库分析的基本能力。在这里记录基本的分析流程手法。 0x01 逆向分析&#xff1a; 一、使用 Genym…

视频汇聚平台LntonCVS视频集中存储平台技术解决方案

安防视频监控技术是一种利用各种监控设备捕捉实时画面&#xff0c;并将其传输至监控中心或数据存储设备的技术。随着科技的不断进步&#xff0c;监控视频技术也在不断改进&#xff0c;应用领域也在不断扩展。 然而&#xff0c;尽管技术进步&#xff0c;当前视频监控技术仍然面临…

线性代数基础概念:向量空间

目录 线性代数基础概念&#xff1a;向量空间 1. 向量空间的定义 2. 向量空间的性质 3. 基底和维数 4. 子空间 5. 向量空间的例子 总结 线性代数基础概念&#xff1a;向量空间 向量空间是线性代数中最基本的概念之一&#xff0c;它为我们提供了一个抽象的框架&#xff0c…

WIN版-苹果和平精英画质帧率优化教程

一、视频教程&#xff1a; 想要视频的联系博主 二、图文教程&#xff1a; 前置说明&#xff1a;不按教程&#xff0c;会导致修改不成功&#xff0c;或者设备里面内容丢失。请务必按教程操作&#xff01;&#xff01; 准备工作&#xff08;这部分是在要改的设备上操作&#x…

JAVA每日作业day6.26

ok了家人们&#xff0c;今天我们学习了面向对象-多态&#xff0c;话不多说我们一起来看看吧 一.多态概述 面向对象的第三大特性&#xff1a;封装、继承、多态 我们拿一个生活中的例子来看 生活中&#xff0c;比如跑的动作&#xff0c;小猫、小狗和大象&#xff0c;跑起来是不一…

如何轻松获取 GitLab 指定分支特定路径下的文件夹内容

第一步&#xff1a; 获取 accessToken 及你的 项目 id &#xff1a; 获取 accessToken ,点击用户头像进入setting 按图示操作&#xff0c;第 3 步 填写你发起请求的域名。 获取项目 id , 简单粗暴方案 进入 你项目仓库页面后 直接 源码搜索 project_id&#xff0c; value 就…

基于 elementUI / elementUI plus,实现 主要色(主题色)的一件换色(换肤)

一、效果图 二、方法 改变elementUI 的主要色 --el-color-primary 为自己选择的颜色&#xff0c;核心代码如下&#xff1a; // 处理主题样式 export function handleThemeStyle(theme) {document.documentElement.style.setProperty(--el-color-primary, theme) } 三、全部代…

Fragment与ViewModel(MVVM架构)

简介 在Android应用开发中&#xff0c;Fragment和ViewModel是两个非常重要的概念&#xff0c;它们分别属于架构组件库的一部分&#xff0c;旨在帮助开发者构建更加模块化、健壮且易维护的应用。 Fragment Fragment是Android系统提供的一种可重用的UI组件&#xff0c;它能够作为…

nacos在k8s上的集群安装实践

目录 概述实践nfs安装使用 k8s持久化nacos安装创建角色部署数据库执行数据库初始化语句部署nacos ingress效果展示 结束 概述 本文主要对 nacos 在k8s上的集群安装 进行说明与实践。主要版本信息&#xff0c;k8s: 1.27.x&#xff0c;nacos: 2.0.3。运行环境为 centos 7.x。 实…
最新文章