liding
4 天以前 359f69135b571c8e7b6d046bc849655abfe7075d
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
// +----------------------------------------------------------------------
// | 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没有传值的情况下给的提示 
    }
  }
}