1.设计菜单实体

import java.util.List;

public class Menu {
//菜单id
private Long id;
//父节点id
private Long parentId;
//菜单名称
private String name;
//对应路径
private String url;
//图标
private String icon;
//是否选中
private boolean selected; private List<Menu> childrens; public Long getId() {
return id;
} public void setId(Long id) {
this.id = id;
} public Long getParentId() {
return parentId;
} public void setParentId(Long parentId) {
this.parentId = parentId;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public String getUrl() {
return url;
} public void setUrl(String url) {
this.url = url;
} public String getIcon() {
return icon;
} public void setIcon(String icon) {
this.icon = icon;
} public boolean isSelected() {
return selected;
} public void setSelected(boolean selected) {
this.selected = selected;
} public List<Menu> getChildrens() {
return childrens;
} public void setChildrens(List<Menu> childrens) {
this.childrens = childrens;
} }

2.工具类如下:

import java.util.ArrayList;
import java.util.List; import com.alibaba.fastjson.JSONObject;
/**
* 构建树形菜单
* MenuUtils
* @author lishang
* 2018年8月30日
*/
public class MenuUtils {
/**
* 针对二级菜单
* treeMenuList:( ). <br/>
* @author lishang
* @param sourceList
* @return
*/
public static List<Menu> treeMenuList(List<Menu> sourceList){
List<Menu> targetList=new ArrayList<>();
if (sourceList==null) {
return null;
}
List<Menu> pmenus=new ArrayList<>();
for (Menu menu : sourceList) {
if(menu.getParentId()==0l||menu==null){
pmenus.add(menu);
}
}
sourceList.removeAll(pmenus);
for (int i = 0; i < pmenus.size(); i++) {
Menu pmenu=pmenus.get(i);
List<Menu> cmenus=new ArrayList<>();
for (Menu menu : sourceList) {
if(pmenu.getId().equals(menu.getParentId())){
cmenus.add(menu);
}
}
pmenu.setChildrens(cmenus);
sourceList.removeAll(cmenus);
}
return targetList;
} public static List<Menu> treeRoot(List<Menu> sourceList){ return sourceList;
} /**
* 递归获取菜单
* treeRoot:( ). <br/>
* @author lishang
* @param sourceList
* @param rootMenu
* @return
*/
public static Menu treeRoot(List<Menu> sourceList,Menu rootMenu)
{
if (sourceList == null)
{
return null;
}
List<Menu> childList=new ArrayList<>();
for (Menu menu : sourceList) {
if(rootMenu.getId().equals(menu.getParentId())){
Menu menuChild = treeRoot(sourceList, menu);
childList.add(menuChild);
}
}
if(childList.size()==0){
return rootMenu;
}
rootMenu.setChildrens(childList);
return rootMenu;
} public static void main(String[] args) {
List<Menu> sourceList=new ArrayList<>(); Menu menu=new Menu();
menu.setParentId(0l);
menu.setId(1l);
menu.setName("菜单一级");
sourceList.add(menu); Menu menu2=new Menu();
menu2.setParentId(1l);
menu2.setId(2l);
menu2.setName("菜单二级1");
sourceList.add(menu2); Menu menu3=new Menu();
menu3.setParentId(2l);
menu3.setId(3l);
menu3.setName("菜单三级");
sourceList.add(menu3); Menu menu4=new Menu();
menu4.setParentId(3l);
menu4.setId(4l);
menu4.setName("菜单四级");
sourceList.add(menu4); Menu menu5=new Menu();
menu5.setParentId(1l);
menu5.setId(6l);
menu5.setName("菜单二级2");
sourceList.add(menu5); Menu childrens = treeRoot(sourceList, menu);
System.out.println(JSONObject.toJSON(childrens));
} }

import java.util.List;

public class Menu {
    //菜单id
    private Long id;
    //父节点id
    private Long parentId;
    //菜单名称
    private String name;
    //对应路径
    private String url;
    //图标
    private String icon;
    //是否选中
    private boolean selected;
    
    private List<Menu> childrens;

public Long getId() {
        return id;
    }

public void setId(Long id) {
        this.id = id;
    }

public Long getParentId() {
        return parentId;
    }

public void setParentId(Long parentId) {
        this.parentId = parentId;
    }

public String getName() {
        return name;
    }

public void setName(String name) {
        this.name = name;
    }

public String getUrl() {
        return url;
    }

public void setUrl(String url) {
        this.url = url;
    }

public String getIcon() {
        return icon;
    }

public void setIcon(String icon) {
        this.icon = icon;
    }

public boolean isSelected() {
        return selected;
    }

public void setSelected(boolean selected) {
        this.selected = selected;
    }

public List<Menu> getChildrens() {
        return childrens;
    }

public void setChildrens(List<Menu> childrens) {
        this.childrens = childrens;
    }

}

java构建树形菜单递归工具类的更多相关文章

  1. Java操作文件夹的工具类

    Java操作文件夹的工具类 import java.io.File; public class DeleteDirectory { /** * 删除单个文件 * @param fileName 要删除 ...

  2. 【转】Java压缩和解压文件工具类ZipUtil

    特别提示:本人博客部分有参考网络其他博客,但均是本人亲手编写过并验证通过.如发现博客有错误,请及时提出以免误导其他人,谢谢!欢迎转载,但记得标明文章出处:http://www.cnblogs.com/ ...

  3. Java汉字转成汉语拼音工具类

    Java汉字转成汉语拼音工具类,需要用到pinyin4j.jar包. import net.sourceforge.pinyin4j.PinyinHelper; import net.sourcefo ...

  4. java中excel导入\导出工具类

    1.导入工具 package com.linrain.jcs.test; import jxl.Cell; import jxl.Sheet; import jxl.Workbook; import ...

  5. java中定义一个CloneUtil 工具类

    其实所有的java对象都可以具备克隆能力,只是因为在基础类Object中被设定成了一个保留方法(protected),要想真正拥有克隆的能力, 就需要实现Cloneable接口,重写clone方法.通 ...

  6. java代码行数统计工具类

    package com.syl.demo.test; import java.io.*; /** * java代码行数统计工具类 * Created by 孙义朗 on 2017/11/17 0017 ...

  7. Java加载Properties配置文件工具类

    Java加载Properties配置文件工具类 import org.apache.commons.lang3.StringUtils; import org.apache.log4j.Logger; ...

  8. Java 操作Redis封装RedisTemplate工具类

    package com.example.redisdistlock.util; import org.springframework.beans.factory.annotation.Autowire ...

  9. java后台表单验证工具类

    /** * 描述 java后台表单验证工具类 * * @ClassName ValidationUtil * @Author wzf * @DATE 2018/10/27 15:21 * @VerSi ...

随机推荐

  1. S8-codelab02

    import news_cnn_model import numpy as np import os import pandas as pd import pickle import shutil i ...

  2. java中的编译时常量与运行时常量

    常量是程序运行期间恒定不变的量,许多程序设计语言都有某种方式,向编译器告知一块数据是恒定不变的,例如C++中的const和Java中的final. 根据编译器的不同行为,常量又分为编译时常量和运行时常 ...

  3. C语言基础01

    1. 用scanf清理缓冲区数据 scanf("%*[^\n]"); scanf("%*c"); 2. 格式转换 将无符号整型数value转换成字符串并返回该字 ...

  4. gitlab中批量删除本地以及远程tag的操作

    git 批量删除标签# 删除所有远程标签git show-ref --tag | awk '{print ":" $2}' | xargs git push origin # 删除 ...

  5. 解题(DirGraCheckPath--有向图的遍历(深度搜索))

    题目描述 对于一个有向图,请实现一个算法,找出两点之间是否存在一条路径. 给定图中的两个结点的指针DirectedGraphNode* a, DirectedGraphNode* b(请不要在意数据类 ...

  6. selenium调用webdriver异常

    使用selenium调用webdriver的时候报错. from selenium import webdriver browser = webdriver.Chrome() browser.get( ...

  7. redis目前最好用的客户端推荐

  8. docker简单搭建gitlab

    docker启动非常简单: docker run --detach --hostname 192.168.0.33 --publish 443:443 --publish 80:80 \ --publ ...

  9. 项目总结22:Java UDP Socket数据的发送和接收

    项目总结22:Java UDP Socket数据的发送和接收 1-先上demo 客户端(发送数据) package com.hs.pretest.udp; import java.io.IOExcep ...

  10. Winform文本框只能输入限定的文本

    比如WInform中的文本框只能输入数字活着字母和退格键,e.kaychar(按下键盘的值)