Vue3中使用自定义指令实现后台管理系统中对于按钮权限的控制

devtools/2024/10/21 3:15:55/

一、自定义指令的全局注册

  1. 创建自定义指令: 你可以创建一个自定义指令来实现某种功能,比如改变文本颜色。

    Vue.directive('color', {bind(el, binding) {el.style.color = binding.value; // 使用绑定的值设置颜色}
    });
    
  2. 全局注册自定义指令: 在 Vue 应用的入口文件(通常是 main.jsapp.js)中进行注册。

    import Vue from 'vue';
    import App from './App.vue';// 全局注册自定义指令
    Vue.directive('color', {bind(el, binding) {el.style.color = binding.value; // 使用绑定的值设置颜色}
    });new Vue({render: h => h(App),
    }).$mount('#app');
    
  3. 在模板中使用: 你可以在任何组件中使用这个指令。

    <template><div v-color="'red'">这段文本将会是红色</div>
    </template>
    

二、 按钮权限详解

本质是控制页面上的按钮显示与否

当我们从后端拿取到一个角色的按钮权限列表(一般是一个字符串数组),通过自定义指令去检查当前用户的角色是否在权限数组中,匹配上证明该角色有这个按钮权限,那么在相应的页面中也有对应按钮的显示,反之没有显示按钮或者按钮被禁用。

三、具体实现

1.在src中创建directive文件夹下的index.ts文件中

import type { App } from 'vue';
import permission from './permission';export default {install(Vue: App) {Vue.directive('permission', permission);}
};

2.在directive文件夹下创建permission文件夹下的index.ts文件中

import type { DirectiveBinding } from 'vue';// 定义一个函数 checkPermission,用于检查元素的权限
function checkPermission(el: HTMLElement, binding: DirectiveBinding) {// 从绑定对象中获取权限值const { value } = binding;// 获取当前角色的按钮权限数组(从后端获取后已经存储到本地了)const btnAclArr = JSON.parse(localStorage.getItem('permissionButtton'));// 检查 value 是否为数组if (Array.isArray(value)) {// 确保数组不为空if (value.length > 0) {const permissionValues = value[0];// 检查当前用户的角色是否在权限数组中const hasPermission = btnAclArr.includes(permissionValues);// 如果没有权限且元素有父节点,移除该元素if (!hasPermission && el.parentNode) {el.parentNode.removeChild(el);}}} else {// 如果 value 不是数组,抛出错误throw new Error(`need roles! Like v-permission="['admin','user']"`);}
}// 导出一个对象,定义自定义指令的生命周期钩子
export default {// 在元素挂载时调用 checkPermission 函数mounted(el: HTMLElement, binding: DirectiveBinding) {checkPermission(el, binding);},// 在元素更新时调用 checkPermission 函数updated(el: HTMLElement, binding: DirectiveBinding) {checkPermission(el, binding);}
};

3.在页面上的按钮添加v-permission属性

 <a-buttonv-permission="['acl:api:add']"type="primary"@click="addApi()"
><template #icon><icon-plus /></template>新建
</a-button>


http://www.ppmy.cn/devtools/127451.html

相关文章

[Python学习日记-50] Python 中的序列化模块 —— pickle 和 json

[Python学习日记-50] Python 中的序列化模块 —— pickle 和 json 简介 pickle 模块 json 模块 pickle VS json 简介 什么叫序列化&#xff1f; 序列化指的是将对象转换为可以在网络上传输或者存储到文件系统中的字节流的过程。序列化使得对象可以被保存、传输和恢复&#…

java实现redis的消息发送和消费,类似kafka功能

确保在 pom.xml 中添加了 Spring Data Redis 和 Jedis 的依赖。如下所示&#xff1a;<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId> </dependency> <dependency&g…

计算机前沿技术-人工智能算法-大语言模型-最新研究进展-2024-10-16

计算机前沿技术-人工智能算法-大语言模型-最新研究进展-2024-10-16 目录 文章目录 目录1. Leveraging Social Determinants of Health in Alzheimers Research Using LLM-Augmented Literature Mining and Knowledge Graphs2. Alignment Between the Decision-Making Logic of …

三菱PLC伺服-停止位置不正确故障排查

停止位置不正确时&#xff0c;请确认以下项目。 1)请确认伺服放大器(驱动单元)的电子齿轮的设定是否正确。 2&#xff09;请确认原点位置是否偏移。 1、设计近点信号(DOG)时&#xff0c;请考虑有足够为0N的时间能充分减速到爬行速度。该指令在DOG的前端开始减速到爬行速度&…

Linux下的杀毒软件介绍

Linux下的杀毒软件介绍 一、Linux杀毒软件的基本概念和作用二、Linux杀毒软件的选择三、Linux杀毒软件推荐四、Linux杀毒软件对应用进程的影响五、结论在当今数字化和网络化的环境中,保护计算机系统的安全至关重要。尽管Linux操作系统因其开源、稳定且相对安全的特性而较少受到…

【HarmonyOS NEXT】权限申请及应用设置页跳转

关键词&#xff1a;鸿蒙、程序访问控制、定位、应用详情页、startability、want 在app开发过程中&#xff0c;常进行系统权限的申请以提供设备访问或个性化功能&#xff08;如扫一扫、城市定位、剪贴板等&#xff09;&#xff0c;从而保障应用功能的完整性&#xff0c;那么本期…

数据结构与算法:数据结构的前沿研究(最终章)

目录 18.1 可持久化数据结构 18.2 随机化数据结构 18.3 内存与存储优化的数据结构 18.4 新兴数据结构与未来趋势 18.5 研究前沿与挑战 总结 数据结构与算法&#xff1a;数据结构的前沿研究&#xff08;最终章&#xff09; 随着计算机科学和技术的不断发展&#xff0c;数…

FPGA实现UDP通信(3)——数据发送实现

基于FPGA实现UDP通信,看完你就懂了!!!(附源码) 上两篇文章分别介绍了UDP通信的物理接口以及UDP通信协议,忘记的同学可以查看我的上几篇文章,介绍有关UDP通信的物理接口文章地址:FPGA实现UDP通信(2)——通信接口简介-CSDN博客 介绍有关UDP通信协议文章地址:FFGA实现UD…