java实现多级菜单(java递归)方法一
生活随笔
收集整理的這篇文章主要介紹了
java实现多级菜单(java递归)方法一
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
查詢菜單樹
public List<Map<String, Object>> queryCategoryInfo() {List<Map<String, Object>> allMenu = queryAllCategory();//根節點List<Map<String, Object>> rootMenu = new ArrayList<Map<String, Object>>();for (Map<String, Object> nav : allMenu) {String parentId = String.valueOf(nav.get("parent_id"));if(parentId.equals("0")){//父節點是0的,為根節點。rootMenu.add(nav);}}/* 根據Menu類的order排序 */ // Collections.sort(rootMenu, order());//為根菜單設置子菜單,getClild是遞歸調用的for (Map<String, Object> nav : rootMenu) {/* 獲取根節點下的所有子節點 使用getChild方法*/String id = String.valueOf(nav.get("category_id"));List<Map<String, Object>> childList = getChild(id, allMenu); // nav.setChildren(childList);//給根節點設置子節點nav.put("child", childList);}return rootMenu;} /*** 獲取子節點* @param id 父節點id* @param allMenu 所有菜單列表* @return 每個根節點下,所有子菜單列表*/private List<Map<String, Object>> getChild(String id,List<Map<String, Object>> allMenu){//子菜單List<Map<String, Object>> childList = new ArrayList<Map<String, Object>>();for (Map<String, Object> nav : allMenu) {// 遍歷所有節點,將所有菜單的父id與傳過來的根節點的id比較//相等說明:為該根節點的子節點。String parentId = String.valueOf(nav.get("parent_id"));if(id.equals(parentId)){childList.add(nav);}}//遞歸for (Map<String, Object> nav : childList) {String tempId = String.valueOf(nav.get("category_id"));//nav.setChildren(,getChild(tempId, allMenu));nav.put("child", getChild(tempId, allMenu));}//Collections.sort(childList,order());//排序//如果節點下沒有子節點,返回一個空List(遞歸退出)if(childList.size() == 0){return new ArrayList<Map<String, Object>>();}return childList;}總結
以上是生活随笔為你收集整理的java实现多级菜单(java递归)方法一的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 适合除夕发朋友圈的唯美文案241个
- 下一篇: 城市发展转型经验交流3篇