@Entity
public class PubComp {
 @Id
 private String aguid; // 菜单ID
 private String pguid; // 父菜单
 private String aname;// 名称

}

public class TreeNode {
  private String id;          //要显示的子节点的ID 
     private String text;        //要显示的子节点的 Text 
     private String iconCls;     //节点的图标 
     private String parentId;    //父节点的ID 
     private List<TreeNode>  children;   //孩子节点的List 
    
     public TreeNode(){}
  public TreeNode(String id, String text, String iconCls,
    String parentId, List<TreeNode> children) {
   super();
   this.id = id;
   this.text = text;
   this.iconCls = iconCls;
   this.parentId = parentId;
   this.children = children;
  }
  public String getId() {
   return id;
  }
  public void setId(String id) {
   this.id = id;
  }
  public String getText() {
   return text;
  }
  public void setText(String text) {
   this.text = text;
  }
  public String getIconCls() {
   return iconCls;
  }
  public void setIconCls(String iconCls) {
   this.iconCls = iconCls;
  }
  public String getParentId() {
   return parentId;
  }
  public void setParentId(String parentId) {
   this.parentId = parentId;
  }
  public List<TreeNode> getChildren() {
   return children;
  }
  public void setChildren(List<TreeNode> children) {
   this.children = children;
  }
  
  //添加子菜单的方法 
     public void addChild(TreeNode node){ 
        if(this.children == null){ 
            children= new ArrayList<TreeNode>(); 
            children.add(node); 
        }else{ 
            children.add(node); 
        } 
            
     }

public String load(ModelMap modelMap){
    List<PubComp> pcList=testCaseDaoImpl.queryPubComp("select p from PubComp p ");   
         modelMap.put("list", pcList); //需要返回的数据(pcList)
        
         List<TreeNode> list = new ArrayList<TreeNode>(); 
         Map map = new HashMap<String, TreeNode>(); 
   
         try { 
   
             //拉出数据库的数据,放入pcList中 
             //将list2中的数据,转换成TreeNode类型,放入Map中备用 
             for (PubComp tDict : pcList) { 
                TreeNode node = new TreeNode(); 
                node.setId(tDict.getAguid()); 
                node.setText(tDict.getAname()); 
                node.setParentId(tDict.getPguid()); 
                map.put(tDict.getAguid(), node); 
   
             } 
             //遍历pcList的数据,把每个节点加入他的父节点的孩子List 
             for (PubComp tDict : pcList) { 
                    if(tDict.getPguid() == null) 
                    { 
                       list.add((TreeNode)map.get(tDict.getAguid())); 
                    }else{ 
   
                       String pidString = tDict.getPguid(); 
                       TreeNode pnode = (TreeNode)map.get(pidString); 
                       TreeNode cnode=(TreeNode)map.get(tDict.getAguid()); 
                       pnode.addChild(cnode); 
                    } 
             }        
            
             //将对象转换成json(注意需要添加gson-2.2.2.jar)
             Gson g = new GsonBuilder().create();
       String json = g.toJson(list,list.getClass());
             System.out.println(json+"-----");
            
            
            
            
         }catch (Exception e) { 
             e.printStackTrace(); 
         }

EasyUI_tree根据数据库数据生成树形结构JSON格式的更多相关文章

  1. Delphi中根据分类数据生成树形结构的最优方法

    一. 引言:    TreeView控件适合于表示具有多层次关系的数据.它以简洁的界面,表现形式清晰.形象,操作简单而深受用户喜爱.而且用它可以实现ListView.ListBox所无法实现的很多功能 ...

  2. Java编程:将具有父子关系的数据库表数据转换为树形结构,支持无限层级

    在平时的开发工作中,经常遇到这样一个场景,在数据库中存储了具有父子关系的数据,需要将这些数据以树形结构的形式在界面上进行展示.本文的目的是提供了一个通用的编程模型,解决将具有父子关系的数据转换成树形结 ...

  3. 树形结构JSON的实现方法

    在Web应用程序开发领域,基于Ajax技术的JavaScript树形控件已经被广泛使用,它用来在Html页面上展现具有层次结构的数据项.目前市场上常见的JavaScript框架及组件库中均包含自己的树 ...

  4. C#生成树形结构泛型类

    C#生成树形结构泛型类,使用方法: ToTree<ShowMessageUpdatesTableTreeViewModel>.ToDo(models) public class ToTre ...

  5. ajax数据请求2(json格式)

    ajax数据请求2(json格式) <!DOCTYPE html> <html> <head> <meta charset="UTF-8" ...

  6. 利用nodejs读取数据库数据生成树结构的json数据

    在做后台管理界面的时候,几乎少不了的一个结构就是树形结构,用来做菜单导航: 那么,最希望的就是树结构的所有数据都是读取的数据库,而不是直接代码当中写死,那我们就一步一步来看: 一,建表 字段通常包括: ...

  7. 数据库索引 引用树形结构 B-数 B+数

    MySQL 为什么使用B+数 B-树和B+树最重要的一个区别就是B+树只有叶节点存放数据,其余节点用来索引,而B-树是每个索引节点都会有Data域. 这就决定了B+树更适合用来存储外部数据,也就是所谓 ...

  8. 递归算法结合数据库 解析 java树形结构

    1.准备表结构及对应的表数据a.表结构: create table TB_TREE ( CID NUMBER not null, CNAME VARCHAR2(50), PID NUMBER //父节 ...

  9. jxl读数据库数据生成xls 并下载

    1.所需jar jxl-2.6.10.jar jxls-core-1.0-RC-3.jar jxls-reader-1.0-RC-3.jar 2. excel修改行宽度封装 SheetColumn.j ...

随机推荐

  1. .net remoting 客户端与服务端绑定事件,一部电脑当服务器,另一部当客户端,发布后没法接收远程错误信息。

    可以是用下面代码抛出远程错误,客户端和服务端都要设置,因为服务端事件回调时角色变成了远程客户端了. RemotingConfiguration.CustomErrorsMode = CustomErr ...

  2. IOS中微博正文开发步骤总结

    微博正文开发步骤总结 1.新建正文控制器,在点击首页的某一条微博时跳转过去 2.在MainController中设置导航控制器的代理,监听所有导航控制器的跳转 1> 如果即将显示的不是根控制器 ...

  3. 利用android proguard混淆代码

    利用android proguard混淆代码 2014-02-05 17:50 1207人阅读 评论(1) 收藏 举报 网上虽然有很多相关博客,不过貌似都不是最新版的..于是百度+谷歌+github上 ...

  4. Bootstrap-select:美化原生select

    官网:http://silviomoreto.github.io/bootstrap-select/ 1.下载zip 2.html代码 <select class="selectpic ...

  5. android studio修改新项目package名称

    android项目生成APK发布必须保证package唯一.新项目在已有项目基础上修改就必须修改package名称. 操作如下: 1) 在模块(module)上右键选择Refactor->Ren ...

  6. SmartGit STUDY 2

    The Index The Index is an intermediate cache for preparing a commit. With SmartGit, you can make hea ...

  7. 应用scikit-learn做文本分类(转)

    文本挖掘的paper没找到统一的benchmark,只好自己跑程序,走过路过的前辈如果知道20newsgroups或者其它好用的公共数据集的分类(最好要所有类分类结果,全部或取部分特征无所谓)麻烦留言 ...

  8. WebGoat学习——SQL注入(SQL Injection)

    SQL注入(SQL Injection) 所谓SQL注入式攻击,就是攻击者把SQL命令插入到Web表单的输入域或页面请求的查询字符串,欺骗服务器执行恶意的SQL命令.攻击者通过web请求提交带有影响正 ...

  9. linq数据使用

    取出数据库满足条件的记录的ID,把值放到list中 ) { int userid = Convert.ToInt32(Request.Cookies["id"].Value); v ...

  10. 50+ 响应式的Prestashop电商主题

    PrestaShop是一款针对web2.0设计的全功能.跨平台的免费开源电子商务解决方案,自08年1.0版本发布,短短两年时间,发展迅速,全球已超过四万家网店采用Prestashop进行部署.Pres ...