Java 组装层级菜单及获取层级菜单数据

该博客介绍了如何使用Java处理一个平级的Department集合,将其转换为一个具有层级结构的集合。通过递归方法getDeptTree,遍历当前实体部门列表,根据父ID匹配子部门,并设置子部门的子节点。同时,展示了如何获取有层级集合中所有部门的ID,通过getChildrens方法递归收集所有子部门的ID。这两个方法对于组织结构的构建和数据提取非常有用。
摘要由CSDN通过智能技术生成
将一个平级的集合组装为一个有层级的集合
 private List<Department> getDeptTree(List<Department> currEntDepts, Department department{
        List<Department> children = new ArrayList<>();
        for (Department dept : currEntDepts) {
            if (ObjectUtil.equals(dept.getParentId(), department.getId())) {
                children.add(dept);
                dept.setChildren(getDeptTree(currEntDepts, dept));
            }
        }
        department.setChildren(children);
        return children;
}
获取有层级集合的某个字段数据
public static void getChildrens(List<Department> list, List<Integer> ids) {
    if (list != null) {
        for (Department sysDept : list) {
            ids.add(sysDept.getId());
            List<Department> children = sysDept.getChildren();
            getChildrens(children, ids);
        }
    }
}

实体类

@Data
@EqualsAndHashCode(callSuper = false)
public class Department {

    private Integer id;

    /** 父级id*/
    private Integer parentId;

    private List<Department> children;

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值