Vue中的按钮级权限控制

采用自定义指令来实现

1.在路由的meta属性里配置btnPermissions

path: '/xxx',
name: 'xxx',
meta:{btnPermissions:['admin','normal']},
component: resolve => require(['../xx/xx/xx.vue'], resolve)

2.编写自定义指令

import Vue from 'vue'

/**权限指令**/
const has = Vue.directive('has', {
  bind: function (el, binding, vnode) {
    // 获取页面按钮权限
    let btnPermissionsArr = vnode.context.$route.meta.btnPermissions;
    if (!Vue.prototype.$_has(btnPermissionsArr)) {
      el.parentNode.removeChild(el);
    }
  }
});
// 权限检查方法
Vue.prototype.$_has = function (value) {
  let isExist = false;
  // 获取用户按钮权限
  let btnPermissionsStr = sessionStorage.getItem("btnPermissions");
  if (btnPermissionsStr == undefined || btnPermissionsStr == null) {
    return false;
  }
  if (value.indexOf(btnPermissionsStr) > -1) {
    isExist = true;
  }
  return isExist;
};
export {has}

3.在main.js中引入文件

import has from './plugins/btnPermission.js'
4.在页面中需要控制的按钮处加v-has即可

<el-button @click="xx()" v-has>xx</el-button>

  • 4
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
Vue3 的按钮权限控制可以通过如下步骤实现: 1. 定义权限列表:在后端定义权限列表,包括所有需要控制的操作,如增删改查等。 2. 获取用户权限:在用户登录成功后,从后端获取用户的权限列表。 3. 权限校验:在前端页面需要控制权限按钮或链接,根据用户权限列表判断是否显示或禁用该按钮或链接。 在实际开发,可以将权限校验封装成一个指令或组件,方便重复使用。 以下是一个权限按钮的封装示例: ```vue <template> <button :disabled="!hasPermission" @click="handleClick"> <slot></slot> </button> </template> <script> import { computed } from 'vue' export default { props: { permission: { type: String, required: true } }, setup(props, { emit }) { const userPermissions = ['add', 'update', 'delete'] // 假设用户权限列表为 ['add', 'update', 'delete'] const hasPermission = computed(() => userPermissions.includes(props.permission)) function handleClick() { if (hasPermission.value) { emit('click') } else { // 如果没有权限,可以弹出提示 alert('您没有该操作的权限') } } return { hasPermission, handleClick } } } </script> ``` 在使用时,可以这样写: ```vue <template> <div> <PermissionButton permission="add" @click="handleAdd">添</PermissionButton> <PermissionButton permission="update" @click="handleUpdate">修改</PermissionButton> <PermissionButton permission="delete" @click="handleDelete">删除</PermissionButton> </div> </template> <script> import PermissionButton from '@/components/PermissionButton.vue' export default { components: { PermissionButton }, methods: { handleAdd() { // 执行添操作 }, handleUpdate() { // 执行修改操作 }, handleDelete() { // 执行删除操作 } } } </script> ``` 这样就可以根据用户权限列表控制按钮的显示和禁用了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值