分配权限思路

1.打开权限对话框2.调权限接口展示到树形结构中3.在树形结构中沟选已分配的权限 【重点,也是难点】如何获取当前角色所拥有权限的id1.递归实现: getCheckedRightsIds(node,arr) { //当前node没有children,意味着node没有子级,则将当前node的id保存到数组中 if(!node.children) { return arr.push(node.id) } //如果
摘要由CSDN通过智能技术生成

1.打开权限对话框

2.调权限接口展示到树形结构中

3.在树形结构中沟选已分配的权限 【重点,也是难点】

如何获取当前角色所拥有权限的id

1.递归实现:
 getCheckedRightsIds(node,arr) {
        //当前node没有children,意味着node没有子级,则将当前node的id保存到数组中
       if(!node.children) {
           return arr.push(node.id)
       }

        //如果node含有children,则用递用调用getCheckedRightsIds函数
       node.children.forEach(subnode=>this.getCheckedRightsIds(subnode,arr))
}
2.不用递归:

//封装一个提取树形结构的数据id的方法
export function getTreeIds(tree) {
  //存放id的数组
  let resultArr = [];
  //存放当前要处理的权限数组
  let tempArr = [];

  tempArr = tempArr.concat(JSON.parse(JSON.stringify(tree)));
  while (tempArr.length) {
    let node = tempArr.shift();
    if (node.children) {
      tempArr = tempArr.concat(node.children);
      delete node["children"];
    } else {
      resultArr.push(node.id);
    }
  }

    return resultArr;
}

4.分配权限


                
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值