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>
相关推荐
巴巴博一30 分钟前
2026 最新:Trae / Cursor 一键接入 taste-skill 完整教程(让 AI 前端告别“AI 味”)
前端·ai·ai编程
kyriewen36 分钟前
半夜三点线上崩了,AI替我背了锅——用AI排错,五分钟定位三年老bug
前端·javascript·ai编程
kyriewen1 小时前
我让 AI 当了 24 小时全年无休的“毒舌考官”
前端·ci/cd·ai编程
hexu_blog1 小时前
vue+java实现图片批量压缩
java·前端·vue.js
IT_陈寒1 小时前
为什么你应该学习JavaScript?
前端·人工智能·后端
lifejump2 小时前
Empire(帝国)CMS 7.5 XSS注入
前端·安全·xss
无风听海2 小时前
OAuth 2.0 前端通道与后端通道深入剖析
前端·oauth
sakiko_2 小时前
UIKit学习笔记8-发送照片、拍摄照片并发送
前端·swift·uikit
_code_bear_2 小时前
OpenSpec CLI 与 OPSX 工作流说明
前端·后端·架构