vue3 组件级权限控制

权限控制程度分为:1. 页面级 2. 组件级 3. 代码级

1. 页面级

这是大部分前端遇到的级别。依靠路由守卫,如果没有权限,就看不到菜单,就进不到页面。不会给页面带来侵入性。什么是侵入性,就是写页面组件的时候,还要考虑权限。

2. 组件级

有没有权限都可以看到页面组件,但是不同权限的人,看到的东西不同。比如按钮,没有权限的操作不了,或者看不到这个按钮。这就会产生一些侵入性,写页面组件的时候,需要考虑到权限。

我们现在要做的就是尽量减少组件级权限控制带来的侵入性。如果权限只是控制可见度的话,我们还可以做优化,如果是不同权限,点击按钮调用不同函数的话,那就不好优化了。现在针对第一种情况来优化。

我们可以用一个权限组件将需要权限控制的组件包裹住。给属性 permissions 传入参数 ,如果权限包含 'sys:user:add' 就显示按钮。

<Authority permissions="sys:user:add"><button>新增用户</button>
</Authority><Authority :permissions="['sys:user:view', 'sys:user:update']"><button>新增用户</button>
</Authority>

如果权限控制的不是显示隐藏,而是控制的能否点击呢,我们这个组件可以交还一些控制权,让开发人员根据情况去控制。通过作用域插槽,返回用户的所有权限 userPermissions。

<Authority><template #default="{ userPermissions }"><button :disabled="!userPermissions.includes('sys:user:add')">新增用户</button></template>
</Authority>

我们这个组件提供了两个功能:一个预设的可见不可见,一个让开发者自行处理。代码如下:

<template><slot v-if="showSlot" :userPermissions="permissions"></slot>
</template><script setup>import { computed } from "vue";import { useAuth } from "./useAuth.js";const props = defineProps({permission: {type: [String, Array],},});const { permissions } = useAuth();const showSlot = computed(() => {if (!props.permission) {// 没传入权限,直接显示return true;}if (!permissions) {// 没有任何权限,直接隐藏return false;}if (Array.isArray(props.permission)) {return props.permission.every((p) => permissions.includes(p));} else {return permissions.includes(props.permission);}});
</script>

3. 代码级(函数级)

哪些权限的人可以调用这个函数,哪些不可以。或者调这个函数产生不同的结果。但是这种情况很少。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/845374.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Flutter 中的 SliverFillViewport 小部件:全面指南

Flutter 中的 SliverFillViewport 小部件&#xff1a;全面指南 Flutter 是一个由 Google 开发的跨平台 UI 框架&#xff0c;它允许开发者使用 Dart 语言来构建高性能、美观的移动、Web 和桌面应用。在 Flutter 的丰富组件库中&#xff0c;SliverFillViewport 是一个用于 Custo…

『ZJUBCA MeetUP』 5月25日线下活动——Aptos 链的动态与应用

2024 求是创新 ZJUBCA Sponsored by the ALCOVE Community TIME&#xff1a;2024/05/25 ADD&#xff1a;浙江大学紫金港校区 --- Alcove 是 Aptos 公链与 Alibaba Cloud 共同打造的亚洲首个 Move 开发者社区&#xff0c;致力于支持开发者使用 Move 语言构建下一代 Web3 应用&am…

Linux的命令补全脚本

一 linux命令补全脚本 Linux的命令补全脚本是一个强大且高效的工具&#xff0c;它能够极大地提高用户在命令行界面的工作效率。这种脚本通过自动完成部分输入的命令或参数&#xff0c;帮助用户减少敲击键盘的次数并降低出错率。接下来将深入探讨其工作原理、安装方式以及如何自…

ffmpeg在特定时间点插入素材

如果要在视频的特定时间戳处插入图片&#xff0c;则可以使用以下命令&#xff1a; ffmpeg -i input.mp4 -i image.png -filter_complex “[0:v][1:v]overlay100&#x1f4af;enable‘between(t,5,10)’” -c:a copy output.mp4 这里使用了enable选项&#xff0c;指定了图片插入…

TPM之VMK密封

本篇文章主要介绍基于TPM的Bitlocker全盘加密时&#xff0c;VMK密钥的密封&#xff08;Seal&#xff09;流程&#xff0c;至于TPM、Bitlocker、密钥保护器、VMK密钥等这些东西是什么&#xff0c;这里不做解释&#xff0c;需要自己脑补一下&#xff08;╮(╯▽╰)╭&#xff09;…

【HarmonyOS】输入框焦点控制实现键盘显隐

【HarmonyOS】输入框焦点控制实现键盘显隐 问题背景&#xff1a; 鸿蒙中输入框控件&#xff0c;TextInput最常见的控制&#xff0c;即&#xff1a;针对输入框焦点控制&#xff0c;获取焦点&#xff0c;失去焦点。达到用户方便操作输入和退出输入。 因为输入框一定会伴随着键盘…

42.开发中对String.format()的使用之空位补齐

用于空位补齐 Int x1; //对于传入的数字做处理&#xff0c;如果传入的数字不足三位&#xff0c;则使用数字0自动补齐 String numString.format(“%”3”d”,x); System.out.println(“num”num);//输出结果为&#xff1a;001 也可以简写成&#xff1a; String num2String…

2024年大屏幕互动源码+动态背景图和配乐素材+搭建教程

2024年大屏幕互动源码动态背景图和配乐素材搭建教程 php宝塔搭建部署活动现场大屏幕互动系统php源码 运行环境&#xff1a;PHPMYSQL 下载源码地址&#xff1a;极速云

jenkins禁用所有job

背景 需要对jenkins做迁移&#xff0c;但是老的jenkins需要保留一段时间&#xff0c;先把老的jenkins所有job禁用掉 禁用多分支pipeline 找到Manage Jenkins>Script Console 输入下面的脚本 import hudson.model.*disableChildren(Hudson.instance.items)def disableChi…

数据库设计:实体关系图

一个良好的设计对于数据库系统至关重要&#xff0c;它可以减少数据冗余&#xff0c;确保数据的一致性和完整性&#xff0c;同时使得数据库易于维护和扩展。 实体关系图&#xff08;Entity-Relationship Diagram、ERD&#xff09;是一种用于数据库设计的结构图&#xff0c;它描…

Webrtc支持HEVC之FFMPEG支持HEVC编解码(一)

一、前言 Webrtc使用的FFMPEG(webrtc\src\third_party\ffmpeg)和官方的不太一样,使用GN编译,各个平台使用了不一样的配置文件 以Windows为例,Chrome浏览器也类似 二、修改配置文件 windows:chromium\config\Chrome\win\x64 其他平台: chromium\config\Chrome\YOUR_SYS…

java函数式接口

函数式接口定义&#xff1a;接口中有且仅有一个抽象方法的接口即为函数式接口&#xff0c;可以使用FunctionalInterface检查定义的接口是否是一个函数式接口&#xff0c;函数式接口可以采用lambda表达式。语法格式如下&#xff1a; import java.util.function.Consumer; Func…

ARM32开发——第一盏灯

&#x1f3ac; 秋野酱&#xff1a;《个人主页》 &#x1f525; 个人专栏:《Java专栏》《Python专栏》 ⛺️心若有所向往,何惧道阻且长 文章目录 开发流程需求分析项目新建代码编写GPIO初始化 程序编译程序烧录烧录扩展&#xff08;熟悉&#xff09;官方烧录器烧录&#xff08;…

自制F1C200S demo板(八、Linux初学3)

uboot执行流程学习 uboot执行流程文件路径&#xff1a; 1、uboot/arch/arm/cpu/arm926ejs/start.S&#xff0c;执行结束会跳转到_main部分&#xff0c;处于下一路径中 2、uboot/arch/arm/lib/crt0.S&#xff0c;执行到 mov r0, #0 bl board_init_f 会跳转到void …

今日总结2024/5/31

今日熟悉了常用库函数,并查集&#xff0c;常用建边方式 明天蓝桥杯国赛随缘了&#xff0c;第一次估计也是最后一次了 LQOJ.269 排列序数 如果用 a b c d 这 4 个字母组成一个串&#xff0c;有 4!24 种&#xff0c;如果把它们排个序&#xff0c;每个串都对应一个序号&#xf…

陪玩小程序都需要怎么做?

开发陪玩小程序需要进行全面的需求分析、功能规划、技术选型、界面设计等一系列步骤。陪玩小程序作为一种新兴的网络服务平台&#xff0c;为用户提供了寻找游戏伙伴、预约陪玩服务等功能&#xff0c;满足了用户在游戏领域的社交互动和技能提升需求。具体分析如下&#xff1a; 需…

一份不知道哪里来的第十五届国赛模拟题

这是一个不知道来源的模拟题目&#xff0c;没有完全完成&#xff0c;只作代码记录&#xff0c;不作分析和展示&#xff0c;极其冗长&#xff0c;但里面有长按短按双击的复合&#xff0c;可以看看。 目录 题目代码底层驱动主程序核心代码关键&#xff1a;双击单击长按复合代码 …

Flutter 中的 SliverPadding 小部件:全面指南

Flutter 中的 SliverPadding 小部件&#xff1a;全面指南 Flutter 是一个功能丰富的 UI 框架&#xff0c;由 Google 开发&#xff0c;允许开发者使用 Dart 语言来构建高性能、美观的跨平台应用。在 Flutter 的滚动组件体系中&#xff0c;SliverPadding 是一个用来为其子 Slive…

今日学会的,刘姥姥进大观园

Git - First-Time Git Setup 下载了Git&#xff0c;会用Git了&#xff1f; 还有这个&#xff1a;学习 HTML5 Canvas 这一篇文章就够了 | 菜鸟教程 (runoob.com) JavaScript 用法 | 菜鸟教程 (runoob.com) 看到这个真的是受益匪浅&#xff0c;我终于懂了一直有的疑惑。 3D可…

js 正则匹配返回所有匹配到的范围

js正则默认不返回匹配到的范围&#xff0c;有些场景用起来就不太方便。如果想针对于匹配到的位置多次操作就要另外想个办法了。 indexOf 这个只能获取到第一个出现的位置&#xff0c;其他位置不太行&#xff0c;这个方法好像就行不通了。 自己一个个找&#xff0c;写个kmp算法感…