vue3实现按钮级别权限控制的两种方法

 更新时间:2025年08月13日 11:54:59   作者:前端小怪兽zmy  
本文给大家介绍vue3实现按钮级别权限控制的两种方法,每种方法结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧

如修改、删除等按钮只对特定租户开放,在main.ts中,发送请求把数据存在sessionStorage中(true/false),最简单的方法,每个要进行权限判断的按钮都是用v-if

方法一:自定义指令

封装自定义指令(同时在main.ts中  app.directive('show-Permission', showPermission)挂载全局)

/**
 * 检查是否有展示权限,sessionStorage.getItem('isWhiteUser')从后端获得
 * @returns 是否有白名单用户的权限
 */
function hasShowPermission(): boolean {
  const isWhiteUser = JSON.parse(sessionStorage.getItem('isWhiteUser')) || null
  return isWhiteUser
}
/**
 * 权限指令逻辑
 * @param el 具体元素
 */
function checkShowPermission(el: HTMLElement) {
  if (!hasShowPermission()) {
    // 无权限时移除元素
    el.parentNode?.removeChild(el)
  }
}
/**
 * 自定义指令:按钮级权限控制
 */
export default {
  mounted(el: HTMLElement) {
    checkShowPermission(el)
  }
}

注意一下优先级:

按钮直接使用:

        <el-button
          type="primary"
          v-show-Permission
          v-preventReClick
          link
          @click="confirm(ConfirmationAction.DELETE, [row])"
          >删除
        </el-button>

注意Vue中规定:

  1. 注册指令时,不能包含 v- 前缀(v- 是模板中使用时的固定前缀)。
  2. 指令名称如果是多个单词,推荐使用短横线分隔命名(如 show-permission),模板中直接用 v-指令名 调用

方法二:封装组件

在Vue 3 中,$attrs 会自动包含所有传递给组件的属性和事件

<template>
  <el-button v-if="hasPermission" v-bind="$attrs">
  <!-- 传递插槽内容(如图标和文本) -->
    <slot />
  </el-button>
</template>
<script setup lang="ts">
import { computed } from 'vue'
// 检查是否有权限
const hasPermission = computed(() => {
    return JSON.parse(sessionStorage.getItem('isWhiteUser')) || null
})
// 声明该组件不继承父组件的属性(让$attrs包含所有传递的属性)
defineOptions({
  inheritAttrs: false
})
</script>

使用:

    <testButton
      v-show-Permission
      v-show="props.activeName == tabNameConfig.CUSTOM"
      v-preventReClick
      type="primary"
      class="btn-blue leftBtn"
      @click="confirm(ConfirmationAction.UPLOAD, [])"
      ><img src="@/assets/images/upload.svg" alt="" />上传
    </testButton>

到此这篇关于vue3实现按钮级别权限控制的两种方法的文章就介绍到这了,更多相关vue按钮级别权限控制内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vue之el-upload使用FormData多文件同时上传问题

    vue之el-upload使用FormData多文件同时上传问题

    这篇文章主要介绍了vue之el-upload使用FormData多文件同时上传问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-05-05
  • Vue专属状态管理库Pinia的使用与实践分享

    Vue专属状态管理库Pinia的使用与实践分享

    在 Vue 的开发中,状态管理是一个不可或缺的部分,尤其是在复杂的应用中,组件之间的状态共享和管理变得至关重要,Pinia 作为 Vue 的专属状态管理库,本文将深入介绍 Pinia 的基础知识、核心功能以及实际使用场景,需要的朋友可以参考下
    2024-11-11
  • 一文带你深入理解Vue3中Composition API的使用

    一文带你深入理解Vue3中Composition API的使用

    Composition API 是 Vue 3 中的一项强大功能,它改进了代码组织和重用,使得构建组件更加灵活和可维护,本文我们将深入探讨 Composition API 的各个方面,希望对大家有所帮助
    2023-10-10
  • vue iview 导航高亮动态设置方式

    vue iview 导航高亮动态设置方式

    这篇文章主要介绍了vue iview 导航高亮动态设置方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-05-05
  • 简单理解vue中Props属性

    简单理解vue中Props属性

    这篇文章主要帮助大家简单的理解vue中Props属性,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-10-10
  • Vue 服务端渲染SSR示例详解

    Vue 服务端渲染SSR示例详解

    这篇文章主要介绍了Vue 服务端渲染SSR示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07
  • Vue3 编写自定义指令插件的示例代码

    Vue3 编写自定义指令插件的示例代码

    这篇文章主要介绍了Vue3 编写自定义指令插件的示例代码,主要包括编写自定义插件,在 main.ts 中加载启用插件的代码介绍,对Vue3自定义指令插件相关知识感兴趣的朋友一起看看吧
    2022-07-07
  • elementPlus 的el-select在提示框关闭时自动弹出的问题解决

    elementPlus 的el-select在提示框关闭时自动弹出的问题解决

    这篇文章主要介绍了elementPlus 的el-select在提示框关闭时自动弹出闭时自动弹出的问题,主要问题就是因为filterable属性,根本解决方案是选中的时候让他失去焦点 el-select有一个visible-change事件,下拉框出现/隐藏时触发,感兴趣的朋友跟随小编一起看看吧
    2024-01-01
  • Vue中nprogress页面加载进度条的方法实现

    Vue中nprogress页面加载进度条的方法实现

    这篇文章主要介绍了Vue中nprogress页面加载进度条的方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • Vue3 全局使用按钮截流指令示例代码

    Vue3 全局使用按钮截流指令示例代码

    这篇文章主要介绍了Vue3 全局使用按钮截流指令示例代码,Vue2与Vue3中的自定义指令实现方式略有不同,但实现的按钮截流功能是类似的,本文通过示例代码给大家介绍的非常详细,需要的朋友可以参考下
    2023-05-05

最新评论