一文搞懂Vue按钮权限

在编写Vue代码的时候,经常会碰到各种权限问题,如:登录权限、路由权限、按钮权限等。今天我们就好好来说一说这个按钮权限到底是怎么一回事。

文章目录

  • 一、概念
  • 二、按钮权限的方式
    • 2.1 自定义指定
    • 2.2 v-if
    • 2.3 函数式渲染
    • 2.4 小结
  • 三、总结

一、概念

权限字面理解的意思就是权力限制,体现在日常业务开发中就是不同的角色对应不同的权力。打个比方:老师的权力是教书育人,医生的权力是救死扶伤,律师的权力是惩恶扬善。

在我们的工作中,经常有一些按钮是需要特定的角色来操作的,比如删除按钮只有管理员可以看到。

唠叨两句:按钮权限是我们开发中很重要的一环,这个思想我们一定要掌握。这才是我们开发一个大型系统所必须的技能。

二、按钮权限的方式

通过本章我讲教给小伙伴们三种实现按钮权限的方式:自定义指令函数式渲染v-if判断

关于按钮权限的场景一般是这样的:比如当我们登录成功之后,后台会返回给我们当前用户对应的角色信息,可能是一个字符串或者可能是一个字符串数组。这样我们就可以通过角色信息来判断是否渲染当前按钮。

2.1 自定义指定

首先我们先使用自定义指令来演示一下我们上边的业务功能。关于自定义指令如何书写,我就不做过多的解释,如果需要,以后会补充相关知识。

  1. 编写template部分

    <div class="container"><button>admin权限按钮</button>
    </div>
    

    模板中button标签是我们的权限按钮

  2. 编写自定义指定:el是我们挂载的元素,binging可以获取传入的值

    <div class="container"><button v-permission="['admin', 'apadmin']">admin权限按钮</button>
    </div><script setup>
    const vPermission = (el, binding) => {// 获取角色数组const roles = binding.value;if (!roles.includes('admin')) {el.remove();}
    }
    <script>
    
  • 注意:通过自定义指令来判断当前角色是否为admin,如果不满足条件我们就移除button标签。

2.2 v-if

v-if和自定义指令类似,我们通过绑定一个函数通过返回值来判断是否显示当前的button标签,具体代码如下:

  • 代码实现

    <div class="container"><button v-if="!isPermission()">admin权限按钮</button>
    </div><script setup>
    // 1. 这里模拟后台返回的角色权限列表
    const roles = ['admin', 'apadmin'];const isPermission = () => {let flag = false;if (!roles.includes('admin')) {flag = true;}return flag;
    }
    

2.3 函数式渲染

这种方式不同于前两种,它是通过一个函数来动态渲染插槽中的内容,这个就类似于我们写一个组件。我认为这种方式要明显好于前面两种,尤其是v-if

  1. 函数实现

    我们创建一个PermComp.js文件,我们暴露出一个方法。

    // PermComp.js 
    import { getCurrentInstance } from 'vue';export default ({ roles }) => {// 1. 获取组件实例const instance = getCurrentInstance();if (roles.includes('admin')) {// 2. 渲染插槽内容return instance.slots && instance.slots.default();}
    }
    
  2. 组件使用

    <template><div class="container"><PermComp :roles="roles"><button>admin权限按钮</button></PermComp></div>
    </template>
    <script setup>
    import PermComp from './views/test/components/PermComp.js';// 后台返回的角色权限列表
    const roles = ['admin', 'apadmin'];
    </script>
    

2.4 小结

这里演示了三种按钮权限实现的方式,然后我有说到最后一个是我比较推荐的,为什么?

因为通过v-if的实现方式我们可以看到,根据Vue的生命周期我们发现,v-if的执行是在我们DOM挂载之后完成的,所以这样会浪费性能。因为这个按钮我们可能根本就不需要,但是我们会有一个挂载-> v-if判断-> 卸载, 这么一个过程。

三、总结

以上是我对于按钮权限的理解,可能还有更高级的写法等着我去探索,另外说几句题外话,最近勇宝打算看一些和个人文化素养相关的书籍,比如为人处事呀,职场等等,有小伙伴推荐一下吗?欢迎评论区留言!!!

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

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

相关文章

如何系统的学习Python——封装

在Python中&#xff0c;封装是一种面向对象编程的概念&#xff0c;通过将类的内部数据和方法隐藏起来&#xff0c;限制外部对其直接访问。 在Python中&#xff0c;封装可以通过以下方式实现&#xff1a; 1. 私有成员&#xff1a; 在Python中&#xff0c;可以通过在属性或方法…

客服提效工具:一键回复,效率翻倍

在快节奏的工作环境中&#xff0c;每一秒都是宝贵的。对于客服人员来说&#xff0c;每天面对的是海量的咨询和回复&#xff0c;如何在保证服务质量的同时&#xff0c;提高工作效率&#xff1f;最近&#xff0c;我被同事安利了一个神奇的工具——客服宝聊天助手。这是一款专为客…

基于单片机的天然气泄漏报警系统设计论文

目 录 摘 要 I Abstract II 1 引 言 1 2天然气泄露检测报警系统的方案设计 4 2.1 方案选择 4 2.2 天然气泄露报警系统的整体设计方案 5 2.2.1天然气泄漏报警器工作原理 5 2.2.2天然气泄漏报警器的结构 5 3天然气泄露报警的硬件部分设计 7 3.1 STC89C52单片机 7 3.2 传感器的选…

IJCAI23 - Continual Learning Tutorial

前言 如果你对这篇文章感兴趣&#xff0c;可以点击「【访客必读 - 指引页】一文囊括主页内所有高质量博客」&#xff0c;查看完整博客分类与对应链接。 本篇 Tutorial 主要介绍了 CL 中的一些基本概念以及一些过往的方法。 Problem Definition Continual Learning 和 Increm…

【MOMO_Tips】批量将word转换为PDF格式

批量将word转换为PDF格式 1.打开文件–>选项–>自定义功能区–>开发工具–>确定 2.点开开发工具&#xff0c;选择第一个visual basic 3.进入页面后找到插入–>模块&#xff0c;就可以看到这样的画面之后将下列vba代码复制粘贴到模块中 Sub ConvertWordsToPd…

进程的内存布局与进程的虚拟地址空间

进程的内存布局 历史沿袭至今&#xff0c;C 语言程序一直都是由以下几部分组成的&#xff1a; ⚫ 正文段。也可称为代码段&#xff0c;这是 CPU 执行的机器语言指令部分&#xff0c;文本段具有只读属性&#xff0c;以防止程序由于意外而修改其指令&#xff1b;正文段是可以共…

精读《React Conf 2019 - Day1》

1 引言 React Conf 2019 在今年 10 月份举办&#xff0c;内容质量还是一如既往的高&#xff0c;如果想进一步学习前端或者 React&#xff0c;这个大会一定不能错过。 希望前端精读成为你学习成长路上的布道者&#xff0c;所以本期精读就介绍 React Conf 2019 - Day1 的相关内…

【报错-大数据技术-Hbase Ranger】hbase创建、删除(表、命名空间)无权限问题,但是向表put、get、scan数据报错

1、问题描述 使用hbase shell执行创建命名空间、创建表、插入数据、获取数据、查看数据、删除命名空间、删除表等命令操作,发现可以创建命名空间、创建表、删除命名空间、删除表,但是插入数据、获取数据、查看数据等操作却报没有权限的问题,但是我已在Ranger上赋予用户test…

2024主流测试工具测评,总有一款适合你!

大家好&#xff01;我是测试元宝~ 在软件开发周期中&#xff0c;测试是确保产品质量的关键环节。随着企业对于软件质量的要求日益提升&#xff0c;测试人员面临着前所未有的挑战&#xff0c;“工欲善其事必先利其器”&#xff0c;选择一款高效、实用的软件测试工具&#xff0c…

LeetCode # 547. 省份数量

547. 省份数量 题目 有 n 个城市&#xff0c;其中一些彼此相连&#xff0c;另一些没有相连。如果城市 a 与城市 b 直接相连&#xff0c;且城市 b 与城市 c 直接相连&#xff0c;那么城市 a 与城市 c 间接相连。 省份 是一组直接或间接相连的城市&#xff0c;组内不含其他没有…

Git 基于ED25519、RSA算法生成 SSH 密钥

Git 基于ED25519、RSA算法生成 SSH 密钥 基于ED25519算法&#xff0c;生成密钥对命令如下&#xff1a; ssh-keygen -t ed25519 -C "邮箱地址"基于RSA算法&#xff0c;生成密钥对命令如下&#xff1a; ssh-keygen -t rsa -C "<注释内容>"基于ED255…

若依集成MybatisPlus步骤

目录 一、新建业务模块二、集成MybatisPlus三、测试 一、新建业务模块 新建Maven模块&#xff0c;并建立如下目录 新模块的pom.xml添加如下内容 <description>业务模块</description><dependencies><!-- Mysql驱动包 --><dependency><groupI…

我的第一个python web 网站

# -*- coding: utf-8 -*-import http.server import socketserver from datetime import datetimePORT 8000import sys# ...class MyHandler(http.server.SimpleHTTPRequestHandler):def do_GET(self):if self.path /:# 如果路径是根路径&#xff0c;返回页面内容self.send_r…

100个Linux操作命令和20个常用脚本

1.100个Linux操作命令 cd - 切换目录:cd /home/userls - 列出目录内容:ls -lmkdir - 创建目录:mkdir new_folderrmdir - 删除空目录:rmdir empty_foldercp - 复制文件或目录:cp source.txt destination.txtmv - 移动或重命名文件或目录:mv old.txt new.txtrm - 删除文件或…

Locust中wait_time中匿名函数使用方法浅析

前言 翻出之前做个压测项&#xff0c;看到locust中对等待时间的实现方式感到好奇&#xff0c;于是总结下来。 源代码实现 def between(min_wait, max_wait):"""Returns a function that will return a random number between min_wait and max_wait.Example:…

thinkphp学习12-数据库的时间查询

传统方式 可以使用>、<、>、<来筛选匹配时间的数据&#xff1b; public function index() {$res Db::name(user)->where(create_time, >, 2018-1-1)->select();dump($res); }可以使用 between 关键字来设置时间的区间&#xff1b; public function in…

如何在Linux系统部署MeterSphere服务并配置固定公网访问地址

文章目录 推荐 前言1. 安装MeterSphere2. 本地访问MeterSphere3. 安装 cpolar内网穿透软件4. 配置MeterSphere公网访问地址5. 公网远程访问MeterSphere6. 固定MeterSphere公网地址 推荐 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#…

pgrouting学习记录

1 数据库尝试 路径规划的算法 pgr_dijkstra,pgr_astar, pgr_ksp,pgr_withpoints_参考1,pgr_withpoints_参考2 其中pgr_ksp 是dijkstra算法和yen算法结合,获取两点之间的k条最短路径 pgr_dijkstra 算法SELECT gid, geom, node, cost, source, target, ST_Reverse(geom) AS fl…

影响APP广告变现收益的4个关键因素

APP的广告收入&#xff08;IAA&#xff09;展示 * eCPM/1000 IAA收入其实是由广告总展示量和每次展示的平均收入共同决定的。所以&#xff0c;提高IAA收入&#xff0c;我们需要双管齐下&#xff1a;同时提高广告总展示量和平均每次展示的收入。 app广告变现对接点击⬇️链接&…

单机版openstack安装

说明&#xff1a; 本文环境&#xff1a;CentOS 7 x64位 1.创建虚拟机 2.在虚拟机中安装 centos 7&#xff08;最小安装&#xff09;&#xff0c;修改主机名&#xff1a;openstack&#xff0c;设置 root 密码&#xff1a;12345678 3. 网卡设置&#xff0c;重启网络服务&#…