controller:
/**
* 查出所有分类以几子分类,以树形结构组装起来
*/
@RequestMapping("/list/tree")
public R list(){
List<CategoryEntity> entities=categoryService.listWithTree();
return R.ok().put("data", entities);
}
Service:
使用Lambda
@Override
public List<CategoryEntity> listWithTree() {
//1、查出所有分类
List<CategoryEntity> entities=baseMapper.selectList(null);
//2、组装成父子的树形结构
List<CategoryEntity> level1Menus=entities.stream().filter((categoryEntity ) ->{
return categoryEntity.getParentCid()==0;
}).map((menu)->{
menu.setChildren(getChildren(menu,entities));
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<CategoryEntity> getChildren(CategoryEntity root,List<CategoryEntity> all){
List<CategoryEntity>children = all.stream().filter(categoryEntity -> {
return categoryEntity.getParentCid()==root.getCatId();
}).map(categoryEntity -> {
//1、找到子菜单
categoryEntity.setChildren(getChildren(categoryEntity,all));
return categoryEntity;
}).sorted((menu1,menu2)->{
//2、菜单排序
return (menu1.getSort()==null?0:menu1.getSort())-(menu2.getSort()==null?0:menu2.getSort());
}).collect(Collectors.toList());
return children;
}