自定义指令(权限指令)

应用场景

项目中需要做到按钮级别的权限控制,使用自定义指令来实现,在自定义指令判断用户权限中来控制组件的显示于隐藏。

定义自定义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>
posted @   Code_HHX  阅读(223)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· 使用C#创建一个MCP客户端
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· Windows编程----内核对象竟然如此简单?
点击右上角即可分享
微信分享提示