1.如果改子类有父类,则把父类加入子类的父ID中
private static List<MentVo> breadthParentFirst(List<MentVo> rootTree) { if (CollectionUtils.isEmpty(rootTree)) { return Lists.newArrayList(); } List<MentVo> mentVoList=Lists.newArrayList(); rootTree.forEach((root) -> { Queue<MentVo> queue = new LinkedList(); queue.offer(root); while (!queue.isEmpty()){ MentVo tree = (MentVo) queue.poll(); List<MentVo> parent = tree.getParent(); if (!CollectionUtils.isEmpty(parent)) { Iterator var5 = parent.iterator(); while (var5.hasNext()) { MentVo child = (MentVo) var5.next(); queue.offer(child); } } mentVoList.add(tree); } }); return mentVoList; }
2.如果父类id不为空,则查询该子类的父类。
Map<String, List<MentVo>> addListMap = departmentList.stream() .filter(depart -> Objects.nonNull(depart.getId())).collect(Collectors.groupingBy(MentVo::getId)); departmentList.forEach((item) -> { if (!CollectionUtils.isEmpty(addListMap.get(item.getParentid()))) { item.setParent(addListMap.get(item.getParentid())); } }); departmentList.forEach((item) -> { item.setLevel(breadthParentFirst(item.getParent()).size()); }); departmentList = departmentList.stream().sorted((x, y) -> { return x.getLevel().compareTo(y.getLevel()); }).collect(Collectors.toList());
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/260321.html