自定义指令(权限指令)
应用场景
项目中需要做到按钮级别的权限控制,使用自定义指令来实现,在自定义指令判断用户权限中来控制组件的显示于隐藏。定义自定义has指令
//自定义权限指令
Vue.directive('has', {
bind: function (el, binding) {
if (!Vue.prototype.$_has(binding.value)) {
if (el.parentNode) {
el.parentNode.removeChild(el)
} else {
el.style.display = 'none'
}
}
},
})
//按钮权限检查方法
Vue.prototype.$_has = function (value) {
let isExist = false
let userPermissions = sessionStorage.getItem('userPermissions')
if (userPermissions == undefined || userPermissions == null) {
return false
}
let userPermissionsList = JSON.parse(userPermissions)
for (let i = 0; i < userPermissionsList .length; i++) {
if (userPermissionsList [i].permission === value) {
isExist = true
break
}
}
return isExist
}
使用方法
<b-button
v-has="'deviceList::Import'"
@click="modalShow = !modalShow"
variant="info">
Import
</b-button>
分类:
Vue 2
, JavaScript
标签:
JavaScript
, Vue
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· 使用C#创建一个MCP客户端
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· Windows编程----内核对象竟然如此简单?