RuoYi | v-if 和 v-hasPermi冲突问题,隐藏el-table-column

需求:根据权限和条件隐藏el-table-column

原代码:

<el-table-column type="selection" width="55" align="center" reserve-selection v-if="istxChange === true" && v-hasPermi="['archives:archiveBak:back']" />

会发生冲突,隐藏不了,试将v-if改为v-show也无效。

解决方法:

使用checkPermi方法:

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
  }
}
<el-table-column type="selection" width="55" align="center" reserve-selection v-if="istxChange === true && checkPermi(['archives:archiveBak:back'])" />
import { checkRole, checkPermi } from '../../utils/permission';
export default {
  methods: {
    checkPermi,
  }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值