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. 代码级(函数级)

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

yqcoder

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值