Java 通过递归实现菜单树形结构

该博客介绍了一种使用Java通过递归方法来构建菜单的树形结构的方法。首先从数据库查询到的数据中筛选出一级菜单,然后通过遍历和递归调用,为每个一级菜单添加其对应的子菜单,最终形成完整的树形结构。此过程涉及到集合操作、字符串处理以及递归算法的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Java 通过递归实现菜单树形结构

// 最终结果集合
	public List<RespMenu> selectMenu() {
		List<RespMenu> finalList = new ArrayList<>();
		// menuList 为数据库查询得到数据
		if (CollectionUtils.isNotEmpty(menuList)){
            //先找到所有的一级菜单
            for (RespMenu menu : menuList) {
                //一级菜单父级菜单Id为空 或者自己和父级菜单Id相同
                if(StringUtils.isBlank(menu.getParentId()) || menu.getMenuId().equals(menu.getParentId())){
                    finalList.add(menu);
                }
            }
            menuList.removeAll(finalList);
            // 为一级菜单设置子菜单,getChild是递归调用的
            for (RespMenu menu : finalList) {
                // 调用私有方法获取子菜单
                menu.setChildren(getChild(menu.getMenuId(),menuList));
            }
        }
        return finalList;
	}
	/**
     * 获取子菜单
     */
    private List<RespMenu> getChild(String menuId,List<RespMenu> menuList){
        //子菜单集合
        List<RespMenu> childList = new ArrayList<>();
        if (CollectionUtils.isNotEmpty(menuList)) {
            for (RespMenu menu : menuList) {
                // 遍历所有节点,将父菜单id与传过来的id比较
                if (StringUtils.isNotBlank(menu.getParentId())) {
                    if (menu.getParentId().equals(menuId)) {
                        childList.add(menu);
                    }
                }
            }
            // 如果有子菜单还有子菜单,把子菜单的子菜单再循环一遍
            for (RespMenu menu : childList) {
                menu.setChildren(getChild(menu.getMenuId(), menuList));
            }
        }
        return childList;
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值