java树形菜单递归查询
时间: 2023-11-04 18:57:50 浏览: 145
Java树形菜单递归查询是一种通过递归算法来获取多级嵌套菜单的方法。在Java中,我们可以通过递归调用方法来实现这个功能。首先,我们需要定义一个接口或者类来描述菜单的结构,其中包括菜单的ID、父级ID和菜单名称等信息。然后,在具体的实现类中,我们可以通过查询数据库或者其他方式获取菜单数据,并通过递归调用方法来构建菜单的层级结构。
在给出的代码示例中,我们可以看到`TestService`接口定义了一个`findMenu`方法,通过传入父类ID来获取菜单的多级信息。在`TestServiceImpl`实现类中,我们首先使用`baseMapper`查询数据库,获取指定父类ID的菜单列表。然后,通过循环遍历列表中的每一个菜单,递归调用`findMenu`方法来获取子菜单,并将其设置为当前菜单的子菜单。最后,返回构建好的菜单列表。
这种递归查询的方式可以有效地获取多级树形结构数据,但需要注意避免出现死循环的情况,例如循环引用或者无限递归等。另外,为了提高性能和减少数据库查询次数,我们可以考虑对查询结果进行缓存或者使用其他优化策略来提升查询效率。
相关问题
java 递归树形菜单
在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.csdn.net/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.csdn.net/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 ]
java递归实现树形菜单
假设我们有以下的树形菜单结构:
```
- 菜单1
- 子菜单1.1
- 子菜单1.2
- 孙菜单1.2.1
- 孙菜单1.2.2
- 菜单2
- 子菜单2.1
```
我们可以定义一个 Menu 类来表示每个菜单项:
```java
class Menu {
String name;
List<Menu> children;
public Menu(String name) {
this.name = name;
children = new ArrayList<>();
}
// 添加子菜单
public void addChild(Menu menu) {
children.add(menu);
}
}
```
接下来,我们可以使用递归的方式来打印整个树形菜单:
```java
class TreeMenu {
public static void printMenu(Menu menu, int level) {
StringBuilder sb = new StringBuilder();
for (int i = 0; i < level; i++) {
sb.append("-");
}
sb.append(menu.name);
System.out.println(sb.toString());
// 递归打印子菜单
for (Menu childMenu : menu.children) {
printMenu(childMenu, level + 1);
}
}
}
public class Main {
public static void main(String[] args) {
// 构建树形菜单
Menu menu1 = new Menu("菜单1");
Menu menu11 = new Menu("子菜单1.1");
Menu menu12 = new Menu("子菜单1.2");
Menu menu121 = new Menu("孙菜单1.2.1");
Menu menu122 = new Menu("孙菜单1.2.2");
menu12.addChild(menu121);
menu12.addChild(menu122);
menu1.addChild(menu11);
menu1.addChild(menu12);
Menu menu2 = new Menu("菜单2");
Menu menu21 = new Menu("子菜单2.1");
menu2.addChild(menu21);
// 打印树形菜单
TreeMenu.printMenu(menu1, 0);
TreeMenu.printMenu(menu2, 0);
}
}
```
输出结果为:
```
-菜单1
--子菜单1.1
--子菜单1.2
---孙菜单1.2.1
---孙菜单1.2.2
-菜单2
--子菜单2.1
```
我们通过递归遍历整棵树,按照菜单层级打印每个菜单项的名称,并加上相应的缩进。
阅读全文