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>
相关推荐
工业甲酰苯胺4 小时前
TypeScript枚举类型应用:前后端状态码映射的最简方案
javascript·typescript·状态模式
brzhang4 小时前
我操,终于有人把 AI 大佬们 PUA 程序员的套路给讲明白了!
前端·后端·架构
止观止5 小时前
React虚拟DOM的进化之路
前端·react.js·前端框架·reactjs·react
goms5 小时前
前端项目集成lint-staged
前端·vue·lint-staged
谢尔登5 小时前
【React Natve】NetworkError 和 TouchableOpacity 组件
前端·react.js·前端框架
Lin Hsüeh-ch'in5 小时前
如何彻底禁用 Chrome 自动更新
前端·chrome
augenstern4167 小时前
HTML面试题
前端·html
张可7 小时前
一个KMP/CMP项目的组织结构和集成方式
android·前端·kotlin
G等你下课7 小时前
React 路由懒加载入门:提升首屏性能的第一步
前端·react.js·前端框架
谢尔登8 小时前
【React Native】ScrollView 和 FlatList 组件
javascript·react native·react.js