el-tab-pane权限不生效解决方案(详细版)

 premission.js

import store from '@/store'

/**
 * 字符权限校验
 * @param {Array} value 校验值
 * @returns {Boolean}
 */
export function checkPermi(value) {
  if (value && value instanceof Array && value.length > 0) {
    const permissions = store.getters && store.getters.permissions
    const permissionDatas = value
    const all_permission = "*:*:*";

    const hasPermission = permissions.some(permission => {
      return all_permission === permission || permissionDatas.includes(permission)
    })

    if (!hasPermission) {
      return false
    }
    return true
  } else {
    console.error(`need roles! Like checkPermi="['system:user:add','system:user:edit']"`)
    return false
  }
}

/**
 * 角色权限校验
 * @param {Array} value 校验值
 * @returns {Boolean}
 */
export function checkRole(value) {
  if (value && value instanceof Array && value.length > 0) {
    const roles = store.getters && store.getters.roles
    const permissionRoles = value
    const super_admin = "admin";

    const hasRole = roles.some(role => {
      return super_admin === role || permissionRoles.includes(role)
    })

    if (!hasRole) {
      return false
    }
    return true
  } else {
    console.error(`need roles! Like checkRole="['admin','editor']"`)
    return false
  }
}

main.js进行调用我这里调用的是checkPermi 

import { checkPermi } from "@/utils/permission";
Vue.prototype.$checkPermi = checkPermi;

在需要用到的页也页面就可以用啦(部分重要代码展示)

 <el-tabs v-model="activeTab" @tab-click="handleTabClick" class="custom-nav-tabs">
            <el-tab-pane v-for="tab in filteredTabs" :key="tab.name" :label="tab.label" :name="tab.name">
            </el-tab-pane>
        </el-tabs>

   allTabs: [
                { label: 'xxxxxx', name: 'board' },
                { label: 'xxxxxx', name: 'peopleLineed' },
                { label: 'xxxxxx', name: 'totalConsume', permission: 'record:consume:daylist' },
                { label: 'xxxxxx', name: 'charline' },
                { label: 'xxxxxx', name: 'customerTotal' },
            ],

  computed: {
        // 标签栏
        filteredTabs() {
            return this.allTabs.filter(tab => {
                if (tab.permission) {
                    return this.$checkPermi([tab.permission]);
                }
                return true;
            });
        },
    },

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值