java遍历菜单树形菜单(父子级菜单)

一般做这种父子级的遍历都用递归,可是对于新手来说不会用递归,不好理解,下面用纯for循环来解决一下,很简单的!

1.实体类

public class MenuCls {

    private Integer mId;
    private Integer pId;
    private String mName;
    private String path;
    private Boolean open=true;
    private Boolean checked=false;
    private List<MenuCls> children = new ArrayList<MenuCls>();
}

2.业务逻辑层

List<MenuCls> childrenMenuClsList(){
        //创建一个新的集合重新存放数据
        List<MenuCls> menuClsList=new ArrayList<>();
        //查询全部父子级菜单
        List<MenuCls> menuCls = menuClsService.childrenMenuClsList();
        //遍历查询
        for (MenuCls menuCl : menuCls) {
            if (menuCl.getPId()==0){//先判断父级(判断pid==0,是0就是父级)说明menuCl对象是父级
                menuClsList.add(menuCl);//存放父级菜单
            }else {//pid不是0的话menuCl对象就是子级就走else
                for (MenuCls cl : menuCls) {
                    if (menuCl.getPId()==cl.getMId()){//根据menuCl的pid(走else了就是子级)==cl的mid(它是父级)判断该菜单是哪个父级菜单的子菜单,并存放到父级菜单里面
                        cl.getChildren().add(menuCl);
                        break;
                    }
                }
            }
        }
        return menuClsList;
    }

3.数据库参考(父级菜单有8个)

 4.结果

 

 


版权声明:本文为weixin_47084532原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。