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>
相关推荐
陈随易18 分钟前
VSCode v1.101发布,MCP极大增强关联万物,基于VSCode的操作系统雏形已初见端倪
前端·后端·程序员
工呈士21 分钟前
Vite 及生态环境:新时代的构建工具
前端·面试
然我24 分钟前
从 Callback 地狱到 Promise:手撕 JavaScript 异步编程核心
前端·javascript·html
LovelyAqaurius26 分钟前
Flex布局详细攻略
前端
雪中何以赠君别28 分钟前
【JS】箭头函数与普通函数的核心区别及设计意义
前端·ecmascript 6
sg_knight30 分钟前
Rollup vs Webpack 深度对比:前端构建工具终极指南
前端·javascript·webpack·node.js·vue·rollup·vite
NoneCoder33 分钟前
Webpack 剖析与策略
前端·面试·webpack
穗余34 分钟前
WEB3全栈开发——面试专业技能点P3JavaScript / TypeScript
前端·javascript·typescript
a别念m1 小时前
webpack基础与进阶
前端·webpack·node.js
芭拉拉小魔仙2 小时前
【Vue3/Typescript】从零开始搭建H5移动端项目
前端·vue.js·typescript·vant