本文主要是对上一次写的 Java递归获取zTree两种树形结构数据 中的第二种 简单数据类型 进行优化。
数据结构:
var nodes = [
{id:1, pId:0, name: "父节点1"},
{id:11, pId:1, name: "子节点1"},
{id:12, pId:1, name: "子节点2"}
];
// 获取简单JSON数据
public static List<Map<String, Object>> getStandardJSON() {
// 根据不同框架获取对应的List数据
List<Map<String, Object>> queryList = query.find();
List<Map<String, Object>> list = Lists.newArrayList();
treeList = getChild(queryList.get(0).get("id") , queryList , list );
return list;
}
public static List<Map<String, Object>> getChild(String id, List<Map<String, Object>> allList, List<Map<String, Object>> simpleList) {
// 子节点
List<Map<String, Object>> childList = Lists.newArrayList();
for (Map<String, Object> map : allList) {
// 遍历所有节点,将父节点id与传过来的id比较
if (!ParamValidUtils.isEmpty(map.get("parent_id"))) {
if (map.get("parent_id").toString().equals(id)) {
simpleList.add(map);
childList.add(map);
}
}
}
// 把子节点的子节点再循环一遍
for (Map<String, Object> map : childList) {
getChild(map.get("id").toString(), allList, simpleList);
}
// 递归退出条件
if (childList.size() == 0) {
return simpleList;
}
return simpleList;
}