日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

java实现多级菜单(java递归)方法一

發布時間:2023/12/31 编程问答 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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递归)方法一的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。