@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. watch 命令实时命令执行监控

    watch 命令   watch -d -n 1 'df; ls -FlAt /path' 在使用这条命令时你需要替换其中的 /path 部分,watch 是实时监控工具,-d 参数会高亮 显示变化的 ...

  2. Google Code Pretiffy 代码 着色 高亮 开源 javascript(JS)库

    1.简介 introduction Google Code Pretiffy 是 Google 的一个用来对代码进行语法着色的 JavaScript 库,支持 C/C++, Java, Python, ...

  3. (四)Logistic Regression

    1 线性回归 回归就是对已知公式的未知参数进行估计.线性回归就是对于多维空间中的样本点,用特征的线性组合去拟合空间中点的分布和轨迹,比如已知公式是y=a∗x+b,未知参数是a和b,利用多真实的(x,y ...

  4. 【英语】Bingo口语笔记(39) - Get系列

  5. 使用Rxjava缓存请求

    最近,我尝试使用RxJava开发了一款闲时备份app.我必须承认,一旦你get到了正确的方式,RxJava几乎感觉就像作弊.一切看起来更简洁,多个请求能够被组合,且非常容易控制.通过在UI线程观察和在 ...

  6. Eclipse无法识别小米2S手机

    某日,发现小米2S手机调试程序,发现Eclipse识别不出该硬件设备. 最后,确认小米2S系统升级后,会把开发者选项-USB调试选项默认关闭,打开即可. ----------------------补 ...

  7. 解决 RaspberryPi 树莓派 NTP服务异常 无法自动同步时间

    sudo nano /etc/ntp.conf 然后找到 # pool.ntp.org maps to about 1000 low-stratum NTP servers. Your server ...

  8. ios 页面传值4种方式(一) 之全局变量

    通用的是用代理的方式实现页面传值,但是有时候利用其它方式也可以很巧妙的解决问题,页面传值一共有4种方式: 1.使用全局变量, SharedApplication,定义一个变量来传递. 2.使用文件,或 ...

  9. 搭建Eclipse、Resin Web开发环境

    搭建Eclipse.Resin Web开发环境 一.当然是安装java开发环境 参看: Java环境的搭建 http://www.cnblogs.com/ghj1976/archive/2010/04 ...

  10. JavaScript对象(document对象 图片轮播)

    图片轮播: 需要注意的HTML需要img标签,他和input标签一样,是非封闭的标签 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Tran ...