java递归实现多级菜单栏_Java构建树形菜单以及支持多级菜单的实例代码

这篇文章主要介绍了Java构建树形菜单的实例代码(支持多级菜单),非常不错,具有参考借鉴价值,需要的朋友可以参考下

效果图:支持多级菜单。

76b7008bee40db976d2c8740cd8b5f16.png

菜单实体类:

public class Menu {

// 菜单id

private String id;

// 菜单名称

private String name;

// 父菜单id

private String parentId;

// 菜单url

private String url;

// 菜单图标

private String icon;

// 菜单顺序

private int order;

// 子菜单

private List

// ... 省去getter和setter方法以及toString方法

}

菜单一般需要排序,我们根据Menu的order字段进行排序:

/*

* 排序,根据order排序

*/

public Comparator

Comparator

@Override

public int compare(Menu o1, Menu o2) {

if(o1.getOrder() != o2.getOrder()){

return o1.getOrder() - o2.getOrder();

}

return 0;

}

};

return comparator;

}

生成树的方法:

public Map findTree(){

Map data = new HashMap();

try {//查询所有菜单

List

//根节点

List

for (Menu nav : allMenu) {

if(nav.getParentId().equals("0")){//父节点是0的,为根节点。

rootMenu.add(nav);

}

}

/* 根据Menu类的order排序 */

Collections.sort(rootMenu, order());

//为根菜单设置子菜单,getClild是递归调用的

for (Menu nav : rootMenu) {

/* 获取根节点下的所有子节点 使用getChild方法*/

List

nav.setChildren(childList);//给根节点设置子节点

}

/**

* 输出构建好的菜单数据。

*

*/

data.put("success", "true");

data.put("list", rootMenu);

return data;

} catch (Exception e) {

data.put("success", "false");

data.put("list", new ArrayList());

return data;

}

}

获取子菜单:

/**

* 获取子节点

* @param id 父节点id

* @param allMenu 所有菜单列表

* @return 每个根节点下,所有子菜单列表

*/

public List

//子菜单

List

for (Menu nav : allMenu) {

// 遍历所有节点,将所有菜单的父id与传过来的根节点的id比较

//相等说明:为该根节点的子节点。

if(nav.ParentId().equals(id)){

childList.add(nav);

}

}

//递归

for (Menu nav : childList) {

nav.setChildren(getChild(nav.getId(), allMenu));

}

Collections.sort(childList,order());//排序

//如果节点下没有子节点,返回一个空List(递归退出)

if(childList.size() == 0){

return new ArrayList

}

return childList;

}

最后返回的JSON串如下:

{

"success": "true",

"list": [

{

"id": "1",

"name": "Java",

"parentid": "0",

"url": "http://www.aliouchen.com",

"order": 1,

"children": [

{

"id": "2",

"name": "并发编程",

"parentid": "1",

"url": "http://www.aliouchen.com",

"order": 1,

"children": []

},

{

"id": "3",

"name": "多线程",

"parentid": "1",

"url": "http://www.aliouchen.com",

"order": 2,

"children": [

"id": "4",

"name": "Thread",

"parentid": "3",

"url": "http://www.aliouchen.com",

"order": 1,

"children":[]

]

}

]

},

{

"id": "5",

"name": "Python",

"parentid": "0",

"url": "http://www.aliouchen.com",

"order": 2,

"children": []

}

]

}

总结

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/555317.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java中clone方法的理解(深拷贝、浅拷贝)

文章目录前言:知识点一:什么是浅拷贝?知识点二:什么是深拷贝?知识点三、java拷贝(clone)的前提:知识点四:浅拷贝案例:拷贝类:测试类:总…

mysql实现内容加密_简单为mysql 实现透明加密方法

一般用户在数据库中保存数据,虽然数据库存储的是二进制,无法直接明文打开查看,但是如果是一个外行人,直接连接进入mysql中,还是可以直接查看数据的。所以对于一些核心数据,特别是企业重要数据资产&#xff…

Arrays.sort() 的一些用法

Arrays.sort() 的一些用法 介绍 sort(T[] a)&#xff1a;对指定T型数组按数字升序排序。sort(T[] a,int formIndex, int toIndex)&#xff1a;对指定T型数组的指定范围按数字升序排序。sort(T[] a, Comparator<? supre T> c): 根据指定比较器产生的顺序对指定对象数组…

foreach 语法糖

// 源码 public class Test {public static void test1() {int[] arr {1, 2, 3, 4, 5};for (int i : arr) {System.out.println(i);}}public static void main(String[] args) {test1();} }// 反编译 public class Test {public Test() {}public static void test1() {int[] a…

DB2连接不上mysql数据库_一次DB2数据库连接失败(SQLSTATE=08001)的解决方法

有一次&#xff0c;在使用DbVisualizer工具连接自己linux虚拟机上的DB2数据库时&#xff0c;报如下错误&#xff1a;Product: DbVisualizer Pro 9.1Build: #2050 (2013/09/08 11:03)Java VM: Java HotSpot(TM)64-Bit Server VMJava Version:1.6.0_43Java Vendor: Sun Microsyst…

Java设置时间为0时0分0秒和23时59分59秒

Calendar calendar Calendar.getInstance(); // 0时0分0秒 calendar.set(Calendar.HOUR_OF_DAY, 0); calendar.set(Calendar.MINUTE, 0); calendar.set(Calendar.SECOND, 0); calendar.set(Calendar.MILLISECOND, 0);// 23时59分59秒 calendar.set(Calendar.HOUR_OF_DAY, 23);…

mysql分片库分页查询_准备开发一个数据库分片的中间件,请问下分页查询用什么样的算法效率较高?...

假设你说的用户&#xff0c;不是开发人员&#xff0c;是终端用户&#xff0c;比如saas之类的系统用户。如果对于用户是透明的&#xff0c;意味着每个用户只需要看到自己的数据&#xff0c;那么比较经济的处理方式是&#xff0c;把用户id的哈希值作为分配的条件&#xff0c;这样…

Java之AQS(AbstractQueuedSynchronizer)

Java之AQS&#xff08;AbstractQueuedSynchronizer&#xff09; AQS 介绍 AQS 的全称为 AbstractQueuedSynchronizer &#xff0c;翻译过来的意思就是抽象队列同步器。这个类在 java.util.concurrent.locks 包下面。 ● 是用来实现锁或者其他同步器组件的公共基础部分的抽象实…

java中Arrays类的讲解

介绍 在java.util中有一个Arrays类&#xff0c;此类包含用于操纵数组的各种方法&#xff0c;例如&#xff1a;二分查找&#xff08;binarySearch&#xff09;、拷贝操作&#xff08;copyOf&#xff09;、比较(equals)、填充(fill)、排序&#xff08;sort&#xff09;等&#xf…

mysql 1055 解决方案_MySQL报错1055解决方案 - 树懒学堂

相信大家在使用MySQL数据库的过程中&#xff0c;或多或少都遇到报错。在mysql版本更新到5.7之后&#xff0c;有一个新的报错出现的次数越来越频繁&#xff0c;它就是MySQL 1055 报错。本文就给大家介绍一下MySQL 1055报错的原因以及解决的思路&#xff0c;并给出两种具体的解决…

SpringBoot 3.0最低版本要求的JDK 17,这几个新特性不能不知道

最近&#xff0c;有很多人在传说 SpringBoot要出3.0的版本了&#xff0c;并且宣布不再支持 Java 8&#xff0c;最低要求是 Java 17了。 其实&#xff0c;早在2021年9月份&#xff0c;关于 Spring Framework 6.0的消息出来的时候&#xff0c;Spring 官方就已经明确了不会向下兼…

jmeter mysql数据导出_Jmeter连接mysql

一、下载添加jar包image.png添加方法&#xff1a;1.拷贝到jmeter/lib目录下&#xff0c;此方法需重启jmeter2.直接在jmeter的测试计划中导入image.png二、连接mysql数据库添加配置元件-JDBC Connection Configurationimage.pngimage.png1.Variable Name for created pool&#…

判断一个坐标点是否在不规则多边形内部的算法

参考&#xff1a;https://wrf.ecse.rpi.edu//Research/Short_Notes/pnpoly.html 在GIS&#xff08;地理信息管理系统&#xff09;中&#xff0c;判断一个坐标是否在多边形内部是个经常要遇到的问题。乍听起来还挺复杂。根据W. Randolph Franklin 提出的PNPoly算法&#xff0c;…

cos7安装mysql_centos7 安装 mysql

centos7 安装 mysql1. 卸载MariaDB, centos 7 自带的[rootesbu-cos7-01 /]# rpm -qa|grep -i mariadb用命令卸载 rpm -e --nodeps2. 官网下载https://dev.mysql.com/downloads/mysql/5.7.html#downloads3. 解压 tar -xvf#tar -xvf mysql-5.7.22-1.el7.x86_64.rpm-bundle由于是…

MySQL中LIMIT的使用方法

一、任务描述 搜索表结构中的某些部分的数据&#xff0c;比如&#xff0c;最后面三个&#xff0c;最前面三个&#xff0c;第2到8条记录&#xff0c;等等。 二、实战演练 1、 select * from tablename order by orderfield desc/asc limit position&#xff0c; counter&#…

mysql++多版本安装_MySQL多版本多实例安装启动

多版本&#xff0c;大版本不同测试多实例&#xff0c;一个MySQL5.7.30一个MySQL8.0.20解压8.0tar -xvf mysql-8.0.20-linux-glibc2.12-x86_64.tartar -xJf mysql-8.0.20-linux-glibc2.12-x86_64.tar.xz改名移动/mysql8.0.20mv mysql-8.0.20-linux-glibc2.12-x86_64 /mysql8.0.2…

MySQL数据库查询优化技巧

1.对查询进行优化&#xff0c;应尽量避免全表扫描&#xff0c;首先应考虑在 where 及 order by 涉及的列上建立索引。 2.应尽量避免在 where 子句中对字段进行 null 值判断&#xff0c;否则将导致引擎放弃使用索引而进行全表扫描&#xff0c;如&#xff1a; select id from t…

cheungssh mysql密码_CheungSSH安装及基本使用

CheungSSH比Ansible的使用更简单&#xff0c;尤其是配置方面&#xff01;而Ansible有的功能&#xff0c; 我的这个程序一样有&#xff0c;和Ansible一样是python开发&#xff0c; 所以跟Ansible的模式一样&#xff0c; 但是CheungSSH 操作更简单&#xff01;配置更轻量&#xf…

MySQL100万条数据的一张表,如何查询优化?

1.两种查询引擎查询速度&#xff08;myIsam 引擎 &#xff09; InnoDB 中不保存表的具体行数&#xff0c;也就是说&#xff0c;执行select count(*) from table时&#xff0c;InnoDB要扫描一遍整个表来计算有多少行。 MyISAM只要简单的读出保存好的行数即可。 注意的是&…

mysql增删改查操作语句_学习笔记-mysql增删改查操作语句

1.mysql增删改查操作语句&#xff1a;1)如果想在一个已经建好的表中添加一列&#xff0c;可以用以下代码&#xff1a;alter table t1 add column addr varchar(20) not null;2)这条语句会向已有的表t1中加入一列&#xff0c;这一列在表的最后一列位置。如果我们希望添加在指定的…