JAVA利用递归返回菜单树

1.菜单类:

import java.util.ArrayList;
import java.util.List;


public class MenuVO {
	private int id;
	private String name;
	private int parentId;
	private List<MenuVO> children;
	
	public int getId() {
		return id;
	}
	public void setId(int id) {
		this.id = id;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public int getParentId() {
		return parentId;
	}
	public void setParentId(int parentId) {
		this.parentId = parentId;
	}
	public List<MenuVO> getChildren() {
		return children;
	}
	public void setChildren(List<MenuVO> children) {
		this.children = children;
	}
	
	public static List<MenuVO> getMenuTree(int parentId,List<MenuVO> menuVOs) {
		List<MenuVO> menuListTree = new ArrayList<MenuVO>();
		for (MenuVO menuVO : menuVOs) {
			if (parentId == menuVO.getParentId()) {
				List<MenuVO> children = getMenuTree(menuVO.getId(), menuVOs);
				if(!children.isEmpty()){
					menuVO.setChildren(children);
				}
				menuListTree.add(menuVO);
			}
		}
		return menuListTree;
		
	}

}

2.测试类:

import java.util.ArrayList;
import java.util.List;


public class Test {
	
	public static void main(String[] args) {
		List<MenuVO> menuVOs = new ArrayList<MenuVO>();
		for (int i = 0; i < 3; i++) {
			MenuVO  menuVO = new MenuVO();
			int id =i+1;
			menuVO.setId(id);
			menuVO.setParentId(0);
			menuVO.setName("menuOne-"+i);
			menuVOs.add(menuVO);
			int count = i+20;
			menuVO = new MenuVO();
			menuVO.setId(count);
			menuVO.setParentId(id);
			menuVO.setName("menuTWO-"+i);
			menuVOs.add(menuVO);
			menuVO = new MenuVO();
			menuVO.setId(i+100);
			menuVO.setParentId(count);
			menuVO.setName("menuTHEE-"+i);
			menuVOs.add(menuVO);
			
		}
		List<MenuVO> menuVOs2 = MenuVO.getMenuTree(0, menuVOs);
		System.out.println(menuVOs2);
	}
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
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 ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值