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

vue3 两种方法实现 按钮级别权限控制

如修改、删除等按钮只对特定租户开放,在main.ts中,发送请求把数据存在sessionStorage中(true/false),最简单的方法,每个要进行权限判断的按钮都是用v-if

方法一:自定义指令

封装自定义指令(同时在main.ts中  app.directive('show-Permission', showPermission)挂载全局)

/*** 检查是否有展示权限,sessionStorage.getItem('isWhiteUser')从后端获得* @returns 是否有白名单用户的权限*/
function hasShowPermission(): boolean {const isWhiteUser = JSON.parse(sessionStorage.getItem('isWhiteUser')) || nullreturn isWhiteUser
}/*** 权限指令逻辑* @param el 具体元素*/
function checkShowPermission(el: HTMLElement) {if (!hasShowPermission()) {// 无权限时移除元素el.parentNode?.removeChild(el)}
}/*** 自定义指令:按钮级权限控制*/
export default {mounted(el: HTMLElement) {checkShowPermission(el)}
}

注意一下优先级:

按钮直接使用:

        <el-buttontype="primary"v-show-Permissionv-preventReClicklink@click="confirm(ConfirmationAction.DELETE, [row])">删除</el-button>

注意Vue中规定:

  1. 注册指令时,不能包含 v- 前缀v- 是模板中使用时的固定前缀)。
  2. 指令名称如果是多个单词,推荐使用短横线分隔命名(如 show-permission),模板中直接用 v-指令名 调用

方法二:封装组件

在Vue 3 中,$attrs 会自动包含所有传递给组件的属性和事件

<template><el-button v-if="hasPermission" v-bind="$attrs"><!-- 传递插槽内容(如图标和文本) --><slot /></el-button>
</template><script setup lang="ts">
import { computed } from 'vue'// 检查是否有权限
const hasPermission = computed(() => {return JSON.parse(sessionStorage.getItem('isWhiteUser')) || null
})// 声明该组件不继承父组件的属性(让$attrs包含所有传递的属性)
defineOptions({inheritAttrs: false
})
</script>

使用:

    <testButtonv-show-Permissionv-show="props.activeName == tabNameConfig.CUSTOM"v-preventReClicktype="primary"class="btn-blue leftBtn"@click="confirm(ConfirmationAction.UPLOAD, [])"><img src="@/assets/images/upload.svg" alt="" />上传</testButton>

http://www.lryc.cn/news/618736.html

相关文章:

  • vue3中el-upload使用http-request方式自定义上传文件
  • 支持任意 MCP 协议的客户端
  • Redis面试题及详细答案100道(16-32) --- 数据类型事务管道篇
  • 一,设计模式-单例模式
  • 2025年中科院2区红杉优化算法Sequoia Optimization Algorithm-附Matlab免费代码
  • VBS 字符串处理
  • 腾讯云服务器账户转移操作详解
  • Ceph存储池参数中pg_num和pgp_num的关系
  • 【Docker项目实战】使用Docker部署Vikunja任务管理工具
  • 熟悉并使用Spring框架 - XML篇
  • 破译真实感:渲染参数进阶指南——告别塑料感,唤醒材质生命力
  • 98、【OS】【Nuttx】【构建】cmake 配置问题定位:menuconfig.dir/build.make
  • 【力扣494】目标和
  • 笔试——Day36
  • Unity-VR插件AutoHand
  • Day 10-2: Mini-GPT完整手写实战 - 从组件组装到文本生成的端到端实现
  • 武汉火影数字|VR红色文化馆打造 沉浸式体验红色文化
  • Coze开源 Agent 的“乐高时代”
  • 【19】万集科技——万集科技嵌入式,校招 一面,二面,面试问答记录
  • Java 编程每日一题:实现一个简易的 LRU 缓存
  • 站在Vue的角度,对比鸿蒙开发中的递归渲染
  • C++单继承虚函数表探索
  • 什么是跨域访问问题,如何解决?
  • 使用 rsync 上传下载文件:详解原理、目录同步和常见问题
  • 间隙锁(Gap Lock)
  • 【C++】5. 内存管理
  • 卫生间装修防水怎么做合适?
  • redis原理篇--Dict
  • 《Linux基础知识-1》
  • Linux随记(二十二)