树形结构
来源:互联网 发布:法兰绒格子衬衫 知乎 编辑:程序博客网 时间:2024/05/23 19:16
@RequestMapping("/loadTreeDepartment")public void loadTreeDepartment(HttpServletResponse response) { Print print = new Print(); List<TBaseDepartment> allDepartments = baseService.loadAllDepartment();查询所有菜单
流化后过滤出根菜单 List<TBaseDepartment> departments = allDepartments.stream().filter(x -> x.getFdepcode() == null || x.getFdepcode().equals("")).collect(Collectors.toList()); List<Map<String, Object>> rightDataTree = getChildren(allDepartments,departments);根据根菜单找出叶子菜单 print.WriteJson(response, rightDataTree);}private List<Map<String, Object>> getChildren(List<TBaseDepartment> listAll, List<TBaseDepartment> pList) { List<Map<String, Object>> list = new ArrayList<Map<String,Object>>(); for (TBaseDepartment department : pList) { Map<String, Object> child = new HashMap<String, Object>(); child.put("id", department.getDepcode()); child.put("text", department.getDepname()); child.put("fid", department.getFdepcode()); child.put("note", department.getNote());
找出每个根菜单的叶子节点 List<TBaseDepartment> childList = listAll.stream().filter(x -> x.getFdepcode() != null && StringUtils.equals(x.getFdepcode(), department.getDepcode())).collect(Collectors.toList()); 直到没有叶子节点if (childList != null) {
遍历查询叶子节点的叶子,直到没有叶子 child.put("children", getChildren(listAll, childList)); child.put("leaf", false); } else { child.put("leaf", true); } list.add(child); } return list;}
0 0
- 树形结构
- 树形结构
- 树形结构
- 树形结构
- 树形结构
- 树形结构
- 树形结构
- 树形结构
- 树形结构
- 组织结构树形结构
- 树形dp+树形结构总结
- 自定义结构--一般树形结构
- 树形结构的实现
- 树形结构的实现
- 树形结构的定位
- 加载树形结构
- ORACLE 树形结构
- 树形结构排序
- vue笔记-----component粒子2
- nodejs与npm升级到最新版本的方法
- android studio 2.3 NDK
- [LeedCode] Single Number II
- MySql之约束
- 树形结构
- Codeforces Round #403 D. Innokenty and a Football League(思维+模拟)
- DrawableLayout实现仿QQ侧滑菜单
- Unicode和Utf-8
- 35 个 Java 代码性能优化总结
- Linux学习日志(2)
- dm8168下qt界面与视频的同步显示
- 建立任务,OSTaskCreateExt()
- 第一次使用yii开发web站点