您的位置:首页 > 健康 > 美食 > 花都建站_小程序加盟招商代理_免费个人网站建站_百度app最新版本

花都建站_小程序加盟招商代理_免费个人网站建站_百度app最新版本

2025/3/29 19:44:53 来源:https://blog.csdn.net/qq_48076747/article/details/146440808  浏览:    关键词:花都建站_小程序加盟招商代理_免费个人网站建站_百度app最新版本
花都建站_小程序加盟招商代理_免费个人网站建站_百度app最新版本

文章目录

  • 一、什么是按钮权限控制
  • 二、思路 (往往是后端返回的权限标识)
    • 三、实现
  • main.ts注册为全局指令
  • 总结


一、什么是按钮权限控制

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

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

后端返回的权限数据模拟

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

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

三、实现

按钮绑定上v-my-point自定义全局指令
代码如下(示例):

<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注册为全局指令

// 自定义按钮权限directive
const myPointDirective:Directive<HTMLElement,string> = (el,binding) => {if (!permissions.includes(user + ":" + binding.value)) {el.style.display = 'none'}}
//  全局注册指令
app.directive('my-point', myPointDirective);

在这里插入图片描述

效果:
后端返回的权限数据没有,则上面按钮就不会显示
在这里插入图片描述
在这里插入图片描述

总结

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

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com