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

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

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

  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.mrgr.cn/news/54896.html

相关文章:

  • 监控易监测对象及指标之:Kafka中间件JMX监控指标解读
  • 如何删除Maven
  • 求刚体移动后的转换矩阵
  • ARM裸机 - ARM体系架构
  • 【AIGC】2024-arXiv-InstantStyle:文本到图像生成中保持风格的免费午餐
  • vue项目常见node错误提示
  • 五年三次冲刺IPO失败,企业业绩成长性恐不足,三年分红约1.5亿元
  • 对比迁移项目的改动
  • 值得收藏学习的人工智能学习框架!
  • 【重学 MySQL】七十三、灵活操控视图数据,轻松掌握视图删除技巧
  • DFF对比
  • SpringBoot运维
  • FHQtreap新模板
  • 诊断知识:NRC78(Response Pending)的回复时刻
  • @RequestMapping(“/api/users“)详细解释一下这行代码
  • 【云从】八、HTTPS流程与建站
  • Redux (八) 路由React-router、嵌套路由、路由传参、路由懒加载
  • 【Android】浅析OkHttp(1)
  • MySQL-29.事务-四大特性
  • web3学习-区块链基础知识
  • 图文深入介绍oracle资源管理(续)
  • 10.20学习
  • Linux基本指令一眼看懂(简洁表示)
  • C语言实践中的补充知识 Ⅱ
  • 【AIGC视频生成】视频扩散模型(综述+最新进展)
  • Python第五节 迷宫王国的奇幻旅程