php 递归生成树形菜单,递归生成树形结构菜单
public List listWithTree() {
//1、查出所有菜單
List categoryEntities = categoryDao.selectList(null);
//2、組裝成父子的樹形結構
//2.1 找到所有的一級分類
List level1Menus = categoryEntities.stream().filter(categoryEntity -> {
return categoryEntity.getParentCid() == 0;
}).map(menu->{
menu.setChildren(getChildrens(menu,categoryEntities));
return menu;
}).sorted((menu1,menu2)->{
return (menu1.getSort()==null?0:menu1.getSort())-(menu2.getSort()==null?0:menu2.getSort());
})
.collect(Collectors.toList());
return level1Menus;
}
//遞歸找到當前菜單的子菜單
private List getChildrens(CategoryEntity root,List all){
List children = all.stream().filter(categoryEntity -> {
return categoryEntity.getParentCid().equals(root.getCatId());
}).map(categoryEntity -> {
categoryEntity.setChildren(getChildrens(categoryEntity,all));
return categoryEntity;
}).sorted((menu1,menu2)->{
return (menu1.getSort()==null?0:menu1.getSort())-(menu2.getSort()==null?0:menu2.getSort());
}).collect(Collectors.toList());
return children;
}
標簽:菜單,return,遞歸,List,categoryEntity,menu2,樹形,menu1,getSort
來源: https://blog.csdn.net/victoyr/article/details/111565348
總結
以上是生活随笔為你收集整理的php 递归生成树形菜单,递归生成树形结构菜单的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 图说字王数格横系列
- 下一篇: DEV 的使用技巧(开学季)