vue3-根据权限点控制按钮进行身份验证通过后再执行按钮事件

在一些管理系统中,经常会涉及到一些敏感操作,比如更改密码/删除人员等行为

为了保证用户信息安全,可在一些敏感操作前进行身份认证,认证通过后才让继续操作,那么我们今天结合自定义指令来实现这一功能

1.封装好你的全局弹窗组件,并在全局文件或入口文件中引入(如:App.vue)

const submit=()=> {
  visible.value = false;
  resolveRef.value && resolveRef.value(true);//更改resolveRef让openSecurityVerification返回的Promise 变为已完成状态
}

// 全局Promise调用方法
let openSecurityVerification;
if (!import.meta.env.SSR) {
  openSecurityVerification = function (options = {}) {
    visible.value = true;
    return new Promise(resolve => {
      resolveRef.value = resolve;
    });
  };
  // 挂载在window上,方便调用
  window.openSecurityVerification = openSecurityVerification;
}

2.封装判断用户是否有权限方法

export const hasAuth= btnPermissions => {
  // 用户的权限码
  // const userStore = useUserStore();
  // const userPermission = userStore.permission;
  const userPermission = ["1001", "1002", "1003"];//权限key数组,一般后端返回

  // 按钮所需单个权限code
  
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值