java中遍历树形菜单,你可能不知道还有这样的方法

版权声明:本文为CSDN博主「穆雄雄」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。

原文链接:https://blog.csdn.net/qq_34137397/article/details/72654955

穆雄雄

开发工具:MyEclipse 10.5

后台框架:Hibernate + Struts2

数据库:Oracle 11g

前台框架:EasyUi

浏览器:谷歌

在开发中我们经常会遇到左边是树形菜单,右边是一个显示列表,单击左边的树形菜单项时,右边会显示该菜单里面相对应的内容。那么左边的树形菜单怎么从数据库里面获取数据在遍历实现呢?我们不妨来看看设计思路。

一个良好的思路是离不开一个设计完美的数据表,那么我们来想想这个数据表怎么设计呢?

先来明确一下思路,我们要用到什么内容:

  1. 当前菜单的编号,我们设为id(不管是在哪个节点上),赞同的朋友们继续往下看!

  2. 既然编号都有了,我们要显示出来不能光有个编号吧,只显示出来1 2   3 .......之类的肯定不靠谱,我们得显示文字,也就是各个编号所对应的文字。我们设为text

  3. 当前的的菜单在哪一节点呢?我们如何来区分呢?大家肯定会想到直接用主外键关联起来,OK,这就好说了,我们在设置个pid,作为每个节点的父id,父id的含义大家肯定都懂,就是当前的节点的父目录是哪个?用这个pid来区分。

  4. 现在有了上面的字段是不是就够了呢?还不够,咱们得再加一个字段,那就是等级levels,这个等级是来区分当前节点是属于二级呢?还是二级的儿子,或者二级的孙子,再或者三级的孙子等等。

我们现在随便举个例子,大家请看:

  • 功能菜单

    • 系统管理

    • 用户管理

      • 个人信息

      • 投票记录

    • 投票管理

      • 维护

      • 发布新投票

      • 所有投票

简要说明一下这个案例

可以看到,一级菜单是功能菜单,他有三个儿子,分别是系统管理,用户管理,投票管理。既然有儿子,那么有孙子是迟早的事,可以看到功能菜单一共有5个孙子。其中老大(系统管理)没儿子,老二(用户管理)有两个儿子,个人信息和投票记录!老三(投票管理)有3个儿子,维护、发布新投票和所有投票。

 我们接着来分析一下数据表:

数据表设计
id
textpidlevels
1
功能菜单
00
2系统管理11
3用户管理11
4
个人信息32
5投票记录32
6投票管理11
7
维护62
8发布新投票62
9所有投票62

对照上面的分析,相信大家都看理解了这个案例了吧!

这里我们只写分析思路,不写代码,源码在这里!!!

接着我们分析怎么在java中实现。

我们这里用到一个前端插件easyui,easyui的 tree,有不懂的可以去百度问问。一搜一大堆,这里就不过多的阐述了。

那么怎么实现呢?

【注意:下面所用到的查询语句均为hql语句,VoteTree是实体类名】

1:我们先查询出最小的levels,也就是根目录,对应案例中的长辈:功能菜单:

Integer minLevel  =    select min(levels) from VoteTree;

2:根据最小level查询所有一级目录   对应案例中长辈的儿子3个:1-1.系统管理      1-          2.用户管理   1-3.投票管理     

List  ts    =  from TreeVote where leves=minLevel;

3:遍历一级目录集合  ts

foreach(VoteTree   tr  :  ts){//根据1级目录ID查找所有子集  getNextLevels(tr.getId)ListtNextLevel=getNextLevels(tr.getId);tr.setTrees(tNextLevel)}

      

4: listgetNextLevels(tr.getId)方法实现

select count(id) from table where pid=tr.getId  保存为总数totoal

    

5:判断totoal

       

listnextLevel  =    from table where pid= tr.getIdlistgetNextLevels(tr.getId){listtvs = getDeeptLevel(tr.getId);}

下面我们就用到一个递归 ,遍历所有的子节点,也就是找孙子; 1-2-1.个人信息     1-2-2.投票记录    1-3-1.维护      1-3-2.发布新投票      1-3-3.所有投票

           

listgetDeeptLevel(TreeVote tvote){listlist= from VoteTree where pid= tvote.getIdif(list.size>0){tvote.add(list);for(int i=0;igetDeeptLevel(list[i]);}}

源码地址:java实现遍历树形菜单方法——设计思路【含源代码】

往期推荐

Mybatis+MySQL动态分页查询数据经典案例(含代码以及测试)

Java基础知识详解之【变量与方法】

Java基础知识详解之【类与接口】

Java基础知识详解之【面向对象】

Java基础知识详解之【基础语法】

Java基础知识详解之【java概述】

SSH(Spring+Struts2+Hibernate)框架搭建步骤(含配置文件以及运行结果)

盛赞!!!最全编程软件安装包免费下载,有了这些开发利器,看谁以后还敢说找不到安装包!(免费领取)

重要说明,粉丝必看【java人脸识别说明】

中控指纹采集器开发指纹识别项目(说明)

使用中控指纹采集器开发指纹识别案例V1.0版

公众号:雄雄的小课堂

CSDN:穆雄雄的博客

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

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

相关文章

Docker-Compose 一键部署Ningx+.Net Core+Redis集群

在看该文章前,你需要对Docker有所了解。 1、创建WebApp应用程序 我使用的是.Net Core 1.0.1版本,创建一个MVC应用程序,并添加对Redis的引用。因为这些很基础,也很简单,这里就不详细说明了,特别提一下有关多…

Catalog Service - 解析微软微服务架构eShopOnContainers(三)

上一篇我们说了Identity Service,因为其基于IdentityServer4开发的,所以知识点不是很多,今天我们来看下Catalog Service,今后的讲解都会把不同的、重点的拿出来讲,希望大家明白。 源码分析 我们先看下它的目录结构&a…

配置环境变量 path

原理 根据windows系统在查找可执行程序的原理,可以将java工具所在路径定义到path 环境变量中,让系统帮我们去找运行执行的程序。 配置方法 我的电脑–属性–高级系统设置–环境变量 编辑 path 环境变量,在变量值开始处加上java工具所在目录…

前端框架选型

前面的话 有一个流传较广的笑话,一个人在stackoverflow中提了一个问题,如何使用javascript实现一个数字与另外一个数字相加。最高票回答是你应该使用jQuery插件,jQuery插件可以做任何事情。 历史总是在重演,以前是jQuery&#xff…

断言、触发器、存储过程

断言 assertion 设置每一门课程最多有60人选修 create assertion a check (60 > all ( select count(*) from sc group by cno) ); drop assertion a; 触发器 trigger 删除触发器 drop tigger a on student 存储过程 定义一个没有返回值的存储过程 create procedure my…

一个java源文件中可以声明多少个class与编译后会生成多少个字节码文件

在一个java源文件中可以声明多个class。 但是,只能最多有一个类声明为public的。 而且要求声明为public的类的类名必须与源文件名相同。 编译的过程 编译以后,会生成一个或多个字节码文件。字节码文件的文件名与java源文件中的类名相同。 运行 只能运…

JavaFX UI控件教程(二)之JavaFX UI控件

翻译自 JavaFX UI控件 本章概述了通过API提供的JavaFX UI控件。 JavaFX UI控件是使用场景图中的节点构建的。因此,控件可以使用JavaFX平台的视觉丰富功能。由于JavaFX API完全用Java实现,因此您可以轻松地将JavaFX UI控件集成到现有的Java应用程序中…

JavaFX UI控件教程(三)之Label

翻译自 Label 本章介绍如何使用Label驻留在javafx.scene.controlJavaFX API包中的类来显示文本元素。了解如何包装文本元素以适合特定空间,添加图形图像或应用视觉效果。 图2-1显示了三种常见的标签用法。左侧的标签是带有图像的文本元素,中间的标签表…

asp.net core中负载均衡场景下http重定向https的问题

上周欣喜地发现,微软官方终于针对 asp.net core 在使用负载均衡的情况下从 http 强制重定向至 https 的问题提供了解决方法。 app.UseForwardedHeaders(new ForwardedHeadersOptions {ForwardedHeaders ForwardedHeaders.XForwardedProto });var options new Rew…

JavaFX UI控件教程(四)之Button

翻译自 Button Button通过JavaFX API提供的类使开发人员能够在用户单击按钮时处理操作。该Button班是的扩展Labeled类。它可以显示文本,图像或两者。图3-1显示了具有各种效果的按钮。在本章中,您将学习如何创建这些按钮类型。 图3-1按钮类型 创建一个按…

.Net Core应用搭建的分布式邮件系统设计

本篇分享的是由NetCore搭建的分布式邮件系统,主要采用NetCore的Api和控制台应用程序,由于此系统属于公司的所以这里只能分享设计图和一些单纯不设计业务的类或方法; 为什么要在公司中首例采用NetCore做开发 为什么要在公司中首例采用NetCore…

JavaFX UI控件教程(五)之Radio Button

翻译自 Radio Button 本章讨论单选按钮控件和RadioButton类,该类的一个专门实现ToggleButton。 可以选择或取消选择单选按钮控件。通常,单选按钮组合成一个组,其中一次只能选择一个按钮。此行为将它们与切换按钮区分开来,因为组…

.NET开源MSSQL、Redis监控产品Opserver之Redis配置

Redis监控数据实例的加载可以查看Opserver.Core项目data/Redis文件夹下的RedisModule.cs,我加了点注释 /// <summary>/// 加载Redis连接 /// </summary>/// <returns></returns>private static List<RedisConnectionInfo> LoadRedisConn…

使用变量注意事项

Java中每个变量必须先声明&#xff0c;后使用(否则会编译失败) 使用变量名来访问这块区域的数据 变量的作用域&#xff1a;其定义所在的一对{ }内 变量只有在其作用域内才有效 同一个作用域内&#xff0c;不能定义重名的变量

JavaFX UI控件教程(六)之Toggle Button

翻译自 Toggle Button 在本章中&#xff0c;您将了解ToggleButton该类&#xff0c;这是通过JavaFX API提供的另一种类型的按钮。 可以将两个或多个切换按钮组合成一个组&#xff0c;其中一次只能选择一个按钮&#xff0c;或者不需要选择。图5-1是组合了三个切换按钮的应用程…

窥探ASP.Net MVC底层原理 实现跨越Session的分布式TempData

Hi,guys!Long time no see! 1、问题的引出 我相信大家在项目中都使用过TempData&#xff0c;TempData是一个字典集合&#xff0c;一般用于两个请求之间临时缓存数据或者页面之间传递消息。也都知道TempData是用Session来实现的&#xff0c;既然是用Session来实现的&#xff0…

某同学正为自己安装不上sqlserver数据库而愁眉苦脸,使用朋友给的方法顿时喜笑颜开,那么朋友到底出了个什么样的方法呢?...

小故事引入&#xff1a;张同学下一节课就要开始学习使用jdbc访问Sql Server数据库了&#xff0c;部分同学由于刚换电脑&#xff0c;导致没有安装数据库&#xff0c;于是同学们按照老师给的方法&#xff08;文末提供老师的方法&#xff09;&#xff0c;将5G多的Sqlserver的安装包…

JavaFX UI控件教程(七)之Checkbox

翻译自 Checkbox 本章教授如何向JavaFX应用程序添加复选框。 虽然复选框看起来类似于单选按钮&#xff0c;但它们不能组合到切换组中以便一次选择多个选项。有关详细信息&#xff0c;请参阅单选按钮和切换按钮章节。 图6-1显示了一个应用程序的屏幕截图&#xff0c;其中三…