自定义指令按钮权限

1、指令文件

javascript 复制代码
// 判断按钮权限逻辑
const checkPermission = (el, binding) => {
  // 获取自定义指令传过来的数组(binding.value)
  const btnRoles = binding.value
  console.log(btnRoles)
  // 取一下本地存的账号权限
  // const userRoles = JSON.parse(localStorage.getItem('role'))
  const userRoles = ['super', 'normal']
  // 判断自定义指令的传值,在账号权限数组中能否找到
  if (btnRoles) {
    // 能找到返回true
    const hasPermission = userRoles.some((v) => {
      return btnRoles.includes(v)
    })
    // 找不到返回false,使用自定义指令的钩子函数,操作dom元素删除该节点
    if (!hasPermission) {
      el.parentNode && el.parentNode.removeChild(el)
    }
  } else {
    throw new Error(`传入关于权限的数组,如 v-permission="['super','normal']"`)
  }
}

// 导出一个对象用作自定义指令的第二个参数
export default checkPermission

2、main.js文件引入,挂载在vue实例上

javascript 复制代码
import checkPermission from './plugins/directive/permission'
const app = createApp({})
app.directive('permission', checkPermission)
app.mount('#app')

3、页面使用

html 复制代码
    <Button v-permission="'super'">super</Button>
    <Button v-permission="'normal'">normal</Button>
    <Button v-permission="'other'">other</Button>
相关推荐
teeeeeeemo14 分钟前
JS数据类型检测方法总结
开发语言·前端·javascript·笔记
Ivy烎2 小时前
STM32学习笔记
笔记·stm32·学习
love530love2 小时前
MSYS2 环境下 Python 开发配置(结合 PyCharm)使用笔记
人工智能·windows·笔记·python·pycharm·virtualenv·uv
车队老哥记录生活3 小时前
【MPC】模型预测控制笔记 (4):约束输出反馈MPC
笔记·算法
speop4 小时前
数学建模会议笔记
笔记·数学建模
忘川w5 小时前
《网络安全与防护》作业复习
笔记·网络安全
AgilityBaby7 小时前
UE5创建蒙太奇动画并播放和在动画蒙太奇中创建动画通知状态
笔记·学习·ue5·游戏引擎·蓝图·蒙太奇动画
wyjcxyyy8 小时前
DIDCTF-应急响应
笔记·ctf·应急响应与电子取证
雁于飞8 小时前
计算机网络与数据通信基础
笔记·计算机网络·考研·学习方法
爱吃煎蛋的小新9 小时前
WPF入门 #1 WPF布局基础
笔记·学习·c#·wpf