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-button
    v-permission="['acl:api:add']"
    type="primary"
    @click="addApi()"
>
    <template #icon>
      <icon-plus />
    </template>
        新建
</a-button>
相关推荐
计算机毕设VX:Fegn0895几秒前
计算机毕业设计|基于springboot + vue高校实验室教学管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
OpenTiny社区5 分钟前
【博文精读】Chrome CSS 2025年回顾
前端·css
m0_6726565412 分钟前
JavaScript性能优化实战技术文章大纲
开发语言·javascript·性能优化
菩提小狗24 分钟前
第3天:基础入门-抓包&封包&协议&APP&小程序&PC应用&WEB应用|小迪安全笔记|网络安全|
前端·安全·小程序
AmsWait24 分钟前
微信H5订阅消息接入实战:样式错乱、返回值解析报错?避坑指南来了
javascript·微信
不爱吃糖的程序媛27 分钟前
在鸿蒙PC上体验JavaScript应用开发:系统信息查看工具
javascript·华为·harmonyos
雨飞飞雨27 分钟前
深度学习响应式系统
前端·vue.js·前端框架
大布布将军31 分钟前
⚡后端安全基石:JWT 原理与身份验证实战
前端·javascript·学习·程序人生·安全·node.js·aigc
ybc465233 分钟前
React、Next安全漏洞问题修复和自测
前端·安全·next.js
huali34 分钟前
社区划分:让AI理解你的代码重构意图
前端·javascript·vue.js