// +----------------------------------------------------------------------
|
// | CMS [ CMS赋能开发者,助力企业发展 ]
|
// +----------------------------------------------------------------------
|
// | Copyright (c) 2016~2021 https://www.CMS.com All rights reserved.
|
// +----------------------------------------------------------------------
|
// | Licensed CMS并不是自由软件,未经许可不能去掉CMS相关版权
|
// +----------------------------------------------------------------------
|
// | Author: CMS Team <admin@CMS.com>
|
// +----------------------------------------------------------------------
|
|
import store from '@/store'
|
|
export default {
|
inserted(el, binding, vnode) {
|
// 当被绑定的元素插入到 DOM 中时……
|
const { value } = binding
|
const all_permission = "*:*:*";
|
//超管标识
|
const permissions = store.getters && store.getters.permissions
|
//从getters中取出从接口请求到的权限标识数组
|
if (value && value instanceof Array && value.length > 0) {
|
//value为指令的绑定值,并且要求是一个非空数组
|
const permissionFlag = value
|
|
const hasPermissions = permissions.some(permission => {
|
//some() 方法用于检测数组中的元素是否满足指定条件(函数提供)
|
//如果是超管或者其他管理员有对应的权限标识
|
return all_permission === permission || permissionFlag.includes(permission)
|
//检测数组 permissionFlag 是否包含 permission
|
})
|
|
if (!hasPermissions) {
|
el.parentNode && el.parentNode.removeChild(el)
|
//否则就删除该节点,体现在页面上就是没有按钮对应的权限标识就不显示该按钮
|
}
|
} else {
|
throw new Error(`请设置操作权限标签值`)
|
//页面上使用v-hasPermi没有传值的情况下给的提示
|
}
|
}
|
}
|