2 回答
TA贡献1811条经验 获得超5个赞
之前做过一个类似的无限级的菜单树,我大概说一下我的思路,具体能不能实现你可以试试,
主要是通过Map
+递归
实现层层嵌套,然后我觉的可以对一级的回复坐分页,结构部分代码你可以参考下:
public class ResourceTree {
public static Map<String, Object> mapArray = new LinkedHashMap<String, Object>();
public List<Resource> menuCommon;
public List<Object> list = new ArrayList<Object>();
public List<Object> menuList(List<Resource> resource) {
this.menuCommon = resource;
for (Resource x : resource) {
Map<String, Object> mapArr = new LinkedHashMap<String, Object>();
if (x.getParentId() == 0) {
mapArr.put("id", x.getId());
mapArr.put("text", x.getResourceName());
mapArr.put("resourceUrl", x.getUrl());
mapArr.put("resourceParent", x.getParentId());
mapArr.put("resourceType", x.getType());
mapArr.put("resourceTag", x.getResourceCode());
// mapArr.put("resourceIcon", x.getResourceIcon());
// mapArr.put("resourceParentPath", x.getResourceParentPath());
mapArr.put("children", menuChild(x.getId()));
list.add(mapArr);
}
}
return list;
}
public List<?> menuChild(int id) {
List<Object> lists = new ArrayList<Object>();
for (Resource a : menuCommon) {
Map<String, Object> childArray = new LinkedHashMap<String, Object>();
if (a.getParentId() == id) {
childArray.put("id", a.getId());
childArray.put("text", a.getResourceName());
childArray.put("resourceUrl", a.getUrl());
childArray.put("resourceParent", a.getParentId());
childArray.put("resourceType", a.getType());
childArray.put("resourceTag", a.getResourceCode());
// childArray.put("resourceIcon", a.getResourceIcon());
// childArray.put("resourceParentPath", a.getResourceParentPath());
childArray.put("children", menuChild(a.getId()));
lists.add(childArray);
}
}
return lists;
}
}
- 2 回答
- 0 关注
- 1335 浏览
添加回答
举报