element tree子节点 默认勾选已知id

个人日常记录,方便查阅

      <el-tree
        ref="tree"
        :data="treeData"
        show-checkbox
        accordion
        :props="treeProps"
        node-key="resourceId"
        :default-expanded-keys="defaultCheckedKeys"
        :default-checked-keys="defaultCheckedKeys"
      >
      </el-tree>
data() {
    return {
      // 树结构
      treeData: [],
      // 树结构以什么展示
      showType: 2,
      treeProps: {
        children: "children",
        label: "resourceName",
      },
      defaultCheckedKeys: [], // 默认勾选
    };
  },
methods:{
   // 获取部门权限详细 permissions
    async getPermissions() {
      const { data } = await permissions({ deptId: this.params.deptId });
/**
 * {"data":[{"systemId": 1,
"systemName": "统一后台管理系统",
"systemShortName": "统一后台管理系统","systemResource":[{
"parentId": -1,
"resourceId": 1,
"resourceName": "首页",
"sortNumber": 10,
"systemId": 1,
"systemName": "统一后台管理系统",
"systemShortName": "统一后台管理系统"
},{
"parentId": -1,
"resourceId": 2,
"resourceName": "组织用户管理",
"sortNumber": 20,
"systemId": 1,
"systemName": "统一后台管理系统",
"systemShortName": "统一后台管理系统"
},]}]}
 */

      data.forEach((v) => {
        this.getPermissionId(v, this.defaultCheckedKeys);
      });
    
      this.$nextTick(() => {
        //  this.$refs.tree.setCheckedKeys(this.defaultCheckedKeys);   这里会把所有的都选上 并没有选到 最底层的子集
      	for (const id of this.defaultCheckedKeys.values()) {
          this.$refs.tree.setChecked(id, true); // 选中检查项
        }
      });
    },
	    // 递归获取默认展示的 key
    getPermissionId(node, arr) {
      if (!node.systemResource) {
        return arr.push(node.resourceId);
      }
      node.systemResource.forEach((item) => {
        this.getPermissionId(item, arr);
      });
    },
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值