多级菜单递归遍历成树

菜单类:
public class Menu {
    // 菜单id
    private String id;
    // 菜单名称
    private String name;
    // 父菜单id
    private String parentId;
    // 菜单url
    private String url;
    // 菜单图标
    private String icon;
    // 菜单顺序
    private int order;
    // 子菜单
    private List<Menu> childMenus;
    // ... 省去getter和setter方法以及toString方法

}

递归主题方法:
 public void testQueryMenuList() {
     // 原始的数据
     List<Menu> rootMenu = menuDao.queryMenuList(null);
     // 查看结果
     for (Menu menu : rootMenu) {
         System.out.println(menu);
     }
     // 最后的结果
     List<Menu> menuList = new ArrayList<Menu>();
     // 先找到所有的一级菜单
     for (int i = 0; i < rootMenu.size(); i++) {
         // 一级菜单没有parentId
         if (StringUtils.isBlank(rootMenu.get(i).getParentId())) {
             menuList.add(rootMenu.get(i));
         }
     }
     // 为一级菜单设置子菜单,getChild是递归调用的
     for (Menu menu : menuList) {
         menu.setChildMenus(getChild(menu.getId(), rootMenu));
     }
     Map<String,Object> jsonMap = new HashMap<>();
     jsonMap.put("menu", menuList);
     System.out.println(gson.toJson(jsonMap));
 }

 private List<Menu> getChild(String id, List<Menu> rootMenu) {
     // 子菜单
     List<Menu> childList = new ArrayList<>();
     for (Menu menu : rootMenu) {
         // 遍历所有节点,将父菜单id与传过来的id比较
         if (StringUtils.isNotBlank(menu.getParentId())) {
             if (menu.getParentId().equals(id)) {
                 childList.add(menu);
             }
         }
     }
     // 把子菜单的子菜单再循环一遍
     for (Menu menu : childList) {// 没有url子菜单还有子菜单
         if (StringUtils.isBlank(menu.getUrl())) {
             // 递归
             menu.setChildMenus(getChild(menu.getId(), rootMenu));
         }
     } // 递归退出条件
     if (childList.size() == 0) {
         return null;
     }
     return childList;
 }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值