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没有传值的情况下给的提示 } }, };