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);

效果:

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

总结

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

相关推荐
red_redemption7 分钟前
自由学习记录(160)
学习
南無忘码至尊8 分钟前
Unity学习90天-第2天-认识Unity生命周期函数并用 Update 控制物体移动,FixedUpdate 控制物理
学习·unity·游戏引擎
重阳微噪26 分钟前
受够了空格翻页?我写了一个 Chrome 自动滚动插件,让你真正沉浸式阅读
前端
Ruihong32 分钟前
你的 Vue 3 reactive(),VuReact 会编译成什么样的 React?
vue.js·面试
Awu122734 分钟前
🍎用 pretext 搞定输入框动态宽度:一个困扰了我三天的 CSS 问题
前端
Ruihong34 分钟前
你的 Vue 3 ref(),VuReact 会编译成什么样的 React?
vue.js·面试
一 乐35 分钟前
酒店预订|基于springboot + vue酒店预订系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·酒店预订系统
萑澈35 分钟前
我用 Cloudflare 搭了一个 FlashInbox 临时邮箱
前端·next.js
报错小能手36 分钟前
ios开发方向——swift错误处理:do/try/catch、Result、throws
开发语言·学习·ios·swift
慕斯fuafua40 分钟前
CSS——盒模型
前端·css