2019-09-10
java實(shí)現(xiàn)多級菜單的方法
在網(wǎng)站開發(fā)的時(shí)候我們會(huì)對網(wǎng)站的欄目進(jìn)行分類,一個(gè)欄目可以有多個(gè)子分類,一個(gè)子分類又可以有分裂
1,查詢菜單樹:
public List<Map<String, Object>> queryCategoryInfo() {
List<Map<String, Object>> allMenu = queryAllCategory();
//根節(jié)點(diǎn)
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")){//父節(jié)點(diǎn)是0的,為根節(jié)點(diǎn)。
rootMenu.add(nav);
}
}
/* 根據(jù)Menu類的order排序 */
// Collections.sort(rootMenu, order());
//為根菜單設(shè)置子菜單,getClild是遞歸調(diào)用的
for (Map<String, Object> nav : rootMenu) {
/* 獲取根節(jié)點(diǎn)下的所有子節(jié)點(diǎn) 使用getChild方法*/
String id = String.valueOf(nav.get("category_id"));
List<Map<String, Object>> childList = getChild(id, allMenu);
// nav.setChildren(childList);//給根節(jié)點(diǎn)設(shè)置子節(jié)點(diǎn)
nav.put("child", childList);
}
return rootMenu;
}
/**
* 獲取子節(jié)點(diǎn)
* @param id 父節(jié)點(diǎn)id
* @param allMenu 所有菜單列表
* @return 每個(gè)根節(jié)點(diǎn)下,所有子菜單列表
*/
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) {
// 遍歷所有節(jié)點(diǎn),將所有菜單的父id與傳過來的根節(jié)點(diǎn)的id比較
//相等說明:為該根節(jié)點(diǎn)的子節(jié)點(diǎn)。
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());//排序
//如果節(jié)點(diǎn)下沒有子節(jié)點(diǎn),返回一個(gè)空List(遞歸退出)
if(childList.size() == 0){
return new ArrayList<Map<String, Object>>();
}
return childList;
}

2,Java 集合 之 List 多級菜單;
package com.menu;
import java.util.List;
public class TestCategory
{
public static String level="";
public static void main(String[] args)
{
MenuManager mm=new MenuManager();
mm.add(new Menu(0,-1,"主控管理系統(tǒng)"));
mm.add(new Menu(100,0,"主控管理"));
mm.add(new Menu(101,0,"公共信息"));
mm.add(new Menu(102,0,"本單位管理"));
mm.add(new Menu(103,0,"下屬管理"));
mm.add(new Menu(104,0,"部門管理"));
mm.add(new Menu(105,0,"職位管理"));
mm.add(new Menu(10000,104,"部門類別"));
mm.add(new Menu(10001,104,"部門信息"));
List<Menu> menuList=mm.getMenuList();
for(int i=0;i<menuList.size();i++)
{
Menu menu=menuList.get(i);
if(menu.getPid()==-1)
{
System.out.println(menu.getName());
showMenu(menu,menuList);
break;
}
}
}
public static void showMenu(Menu parentMenu,List<Menu> menuList)
{
level+="----";
for(int i=0;i<menuList.size();i++)
{
Menu menu=menuList.get(i);
if(menu.getPid()==parentMenu.getId())
{
System.out.println(level+menu.getName());
showMenu(menu,menuList);
}
}
level=level.substring(0,level.length()-4);
}
}
package com.menu;
public class Menu
{
private int id;
private int pid;
private String name;
public Menu(int id, int pid, String name)
{
super();
this.id = id;
this.pid = pid;
this.name = name;
}
public int getId()
{
return id;
}
public void setId(int id)
{
this.id = id;
}
public int getPid()
{
return pid;
}
public void setPid(int pid)
{
this.pid = pid;
}
public String getName()
{
return name;
}
public void setName(String name)
{
this.name = name;
}
}
package com.menu;
import java.util.ArrayList;
import java.util.List;
public class MenuManager
{
private List<Menu> menuList=new ArrayList<Menu>();
public void add(Menu menu)
{
menuList.add(menu);
}
public List<Menu> getMenuList()
{
return menuList;
}
public void setMenuList(List<Menu> menuList)
{
this.menuList = menuList;
}
}
責(zé)任編輯:中山網(wǎng)站建設(shè)
【網(wǎng)訊網(wǎng)絡(luò)】國家高新技術(shù)企業(yè)》十年專注軟件開發(fā),網(wǎng)站建設(shè),網(wǎng)頁設(shè)計(jì),APP開發(fā),小程序,微信公眾號開發(fā),定制各類企業(yè)管理軟件(OA、CRM、ERP、訂單管理系統(tǒng)、進(jìn)銷存管理軟件等)!服務(wù)熱線:0760-88610046、13924923903,http://www.denorpool.com
*請認(rèn)真填寫需求,我們會(huì)在24小時(shí)內(nèi)與您取得聯(lián)系。