Vue3自定义指令实现前端权限控制 - 按钮权限

文章目录


一、什么是按钮权限控制

概念:根据当前用户的权限数据控制按钮的显示和隐藏

二、思路 (往往是后端返回的权限标识)

后端返回的权限数据模拟

c 复制代码
// 模拟权限mock数据
const permissions = [
    "park:bulidng:add",
    "park:bulidng:del",
    "park:bulidng:edit",
]

思路:每一个需要做权限控制的按钮都有一个自己独有的 标识 , 如果标识可以在权限数据列表中找到,则显示,找不到就隐藏

三、实现

按钮绑定上v-my-point自定义全局指令

代码如下(示例):

c 复制代码
  <div class="container">
    <el-button v-my-point="'bulidng:add'" type="success">添加</el-button>
    <el-button v-my-point="'bulidng:del'" type="primary">编辑</el-button>
    <el-button v-my-point="'bulidng:edit'" type="danger">删除</el-button>
  </div>

main.ts注册为全局指令

c 复制代码
// 自定义按钮权限directive
const myPointDirective:Directive<HTMLElement,string> = (el,binding) => {
    if (!permissions.includes(user + ":" + binding.value)) {
        el.style.display = 'none'
    }

}
//  全局注册指令
app.directive('my-point', myPointDirective);

效果:

后端返回的权限数据没有,则上面按钮就不会显示

总结

这样就实现了通过全局自定义指令来实现按钮权限的控制了。

相关推荐
土星碎冰机4 分钟前
xxljob学习(大白话版本)
学习·运维开发
吃好睡好便好36 分钟前
说说免疫力的维护
学习·生活
竹林81840 分钟前
用 wagmi v2 和 viem 手写 NFT 市场批量上架功能,我踩遍了所有异步坑
javascript
ayqy贾杰44 分钟前
基层管理的三板斧,在AI时代行不通了
前端·后端·团队管理
Apifox1 小时前
Apifox 5 月更新|Postman 导入优化、Runner 支持非 root 运行、请求代码自动带鉴权
前端·后端·安全
zithern_juejin1 小时前
数组扁平化
javascript
清溪5491 小时前
n8n表达式沙箱逃逸至RCE漏洞-CVE-2025-68613复现
javascript·安全
miaowmiaow1 小时前
PSD2Code 近期更新与深度解析:从设计稿到生产级代码的完整技术栈
前端·人工智能·ai编程
Hilaku1 小时前
多标签页并发请求导致 Token 刷新失败?只有 15行代码就能解决 !
前端·javascript·程序员
凉、介1 小时前
深入理解 ARMv8-A|处理器模式与寄存器
笔记·学习·嵌入式·arm