java递归返回菜单树

该博客展示了如何使用Java进行递归操作,构建系统菜单的树形结构。通过查询所有菜单并找到根节点,然后递归遍历找出二级及更深层级的菜单,将它们组织成树形结构。主要涉及的类包括SysMenu、LoginUser和菜单服务(menuService),使用了Spring Security的权限注解@PreAuthorize进行权限控制。
/**
 * 获取菜单列表
 */
@PreAuthorize("@ss.hasPermi('system:menu:list')")
@GetMapping("/list")
public AjaxResult list(SysMenu menu)
{
    LoginUser loginUser = tokenService.getLoginUser(ServletUtils.getRequest());
    Long userId = loginUser.getUser().getUserId();
    List<SysMenu> menus = menuService.selectMenuList(menu, userId);
    //查询所有菜单
    //返回的菜单树
    List<SysMenu> rootMenus = new ArrayList<>();
    for (SysMenu sysMenu : menus) {
        //pid(上级Id)为0的是根菜单
        if (0 == sysMenu.getParentId()) {
            rootMenus.add(sysMenu);
        }
    }
    //遍历,找到二级菜单(根菜单的id和所有菜单中的pid比较)
    for (SysMenu rootMenu : rootMenus) {
        List<SysMenu> child = getChild(rootMenu.getMenuId(), menus);
        rootMenu.setChildren(child);
    }
    return AjaxResult.success(rootMenus);
}

/**
 * 递归获取下级菜单
 * @param pid 上级Id
 * @param menus 所有菜单
 * @return
 */
private List<SysMenu> getChild(Long pid, List<SysMenu> menus) {
    //子菜单列表
    List<SysMenu> childList = new ArrayList<>();
    for (SysMenu menu : menus) {
        if (pid == menu.getParentId()) {
            childList.add(menu);
        }
    }
    //遍历 获取子菜单的子菜单
    for (SysMenu menu : childList) {
        List<SysMenu> child = getChild(menu.getMenuId(), menus);
        menu.setChildren(child);
    }
    //递归出口 childList长度为0
    if (childList.size() == 0) {
        return new ArrayList<>();
    }
    return childList;
}
Java中,递归树形菜单的实现可以通过递归获取下级菜单的方法来实现。首先,我们需要获取所有的菜单数据,并将根节点作为起始点。然后,我们可以通过递归的方式为每个根节点建立次级子树,并将子菜单拼接上去。递归的出口是当某个节点没有子菜单时,即为末端节点,我们将空的“树”拼接上去。这样,我们就可以得到一个完整的递归树形菜单。 具体实现的代码如下所示: ``` // 递归获取下级菜单 public List<Menu> getChild(Long pid, List<Menu> menus) { // 子菜单列表 List<Menu> childList = new ArrayList<>(); for (Menu menu : menus) { if (pid.equals(menu.getParentId())) { childList.add(menu); } } // 遍历获取子菜单的子菜单 for (Menu menu : childList) { List<Menu> child = getChild(menu.getId(), menus); menu.setChildren(child); } // 递归出口:当子菜单列表长度为0时,返回一个空的列表 if (childList.size() == 0) { return new ArrayList<>(); } return childList; } // 根据角色id获取菜单对象集合信息 public List<Menu> getAllMenus() { List<Menu> menus = this.loadAll(); // 返回菜单树 List<Menu> rootMenus = new ArrayList<>(); // 获取所有的根节点 for (Menu menu : menus) { if (0 == (menu.getParentId())) { rootMenus.add(menu); } } // 遍历,为根节点建立次级子树并拼接上 for (Menu rootMenu : rootMenus) { List<Menu> child = getChild(rootMenu.getId(), menus); rootMenu.setChildren(child); } return rootMenus; } ``` 这样,通过递归获取下级菜单的方法和根据角色id获取菜单对象集合信息的方法,我们就可以得到一个完整的递归树形菜单。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Java菜单树递归](https://blog.youkuaiyun.com/weixin_39709134/article/details/127746423)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [Java 递归实现树形菜单](https://blog.youkuaiyun.com/baidu_25996713/article/details/125521323)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

8一天不

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值