最近需要用到EASYUI中的TREE功能,以前我是直接拼接成<UL><LI>发现这样拼完之后在更改树后对树的刷新不是很理想,现改用JSON格式,首先分析TREE中JOSN格式如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
[{
    "id":1,
    "text":"流程分类",
    "children":[{
        "id":11,
        "text":"门禁流程分类",
        "checked":true
    },{
        "id":113,
        "text":"子门禁流程分类",
        "children":[{
            "id":1131,
            "text":"子子门禁流程分类"
        },{
            "id": 8,
            "text":"Async Folder",
            "state":"closed"
        }]
    }]
},{
    "id":3
    "text":"行政",
    "children":[{
        "id":"31",
        "text":"加班"
    },{
        "id":"33",
        "text":"请假"
    }]
}]

可以看出这种模式是由三个属性所组成,ID TEXT 集合,根据分析 我们需要对此模式建立一个BEAN的结构模型,建立TREENODE:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
packagecom.odbpo.beans;
 
importjava.util.List;
 
publicclassTreeNode {
 
    privateintid;
 
    privateString text;
     
    privateintpid;
 
    privateList<TreeNode> children;
 
    publicintgetPid() {
        returnpid;
    }
 
    publicvoidsetPid(intpid) {
        this.pid = pid;
    }
 
    publicintgetId() {
        returnid;
    }
 
    publicvoidsetId(intid) {
        this.id = id;
    }
 
    publicString getText() {
        returntext;
    }
 
    publicvoidsetText(String text) {
        this.text = text;
    }
 
    publicList<TreeNode> getChildren() {
        returnchildren;
    }
 
    publicvoidsetChildren(List<TreeNode> children) {
        this.children = children;
    }
}

BEAN构建完成,那么接下来分析如何往BEAN里传数据,首先分析 数据库表中结构

1
2
3
4
5
createtabledepatment(
id,--当前ID
pid,--父ID
name--显示名称
)

接下来我们要建立一个COM.UTIL包,所递归方法放置在这个包下,以便后续多次调用方便

建立类名为:JSONFACTORY

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
/*
     * 以对象形式传回前台
     */
    publicstaticList<TreeNode> buildtree(List<TreeNode> nodes,intid){
        List<TreeNode> treeNodes=newArrayList<TreeNode>();
        for(TreeNode treeNode : nodes) {
            TreeNode node=newTreeNode();
            node.setId(treeNode.getId());
            node.setText(treeNode.getText());
            if(id==treeNode.getPid()){
                node.setChildren(buildtree(nodes, node.getId()));
                treeNodes.add(node);
            }
             
        }
        returntreeNodes;
    }
    

完成以上工作后我们就要在控制器中使用在DAO中建立好的查询方法,这里DAO中写法就不细说了;

控制器写法如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
@RequestMapping("/flow_tree")
@ResponseBody
publicList<TreeNode> getTree(){
    List<TreeNode> nodes=newArrayList<TreeNode>();
    List<FlowSortTable> list_all=flowSortTableServiceImpl.findAll();
    for(FlowSortTable flowSortTable : list_all) {
        TreeNode treeNode=newTreeNode();
        treeNode.setId(flowSortTable.getSortId());
        treeNode.setPid(flowSortTable.getSortPartmentId());
        treeNode.setText(flowSortTable.getSortName());
        nodes.add(treeNode);
    }
    List<TreeNode> treeNodes=JsonTreeFactory.buildtree(nodes,0);
    returntreeNodes;
}

以上工作结束,我们就可以在前台使用EASYUITREE模式了

将此代码 放在$(document).ready(function(){})中

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
$("#tt1").tree({
            url:'${contextPath}/main/flow/flow_tree.html',
            onClick:function(node){
                $("#sort").css("display","block");
                $("#save").hide();
                $("#update").show();
                odbpo_combobox("#flowType",'${contextPath}/main/flow/flowSelect.html',"flowId","flowName");
                varpnode=$(this).tree('getParent',node.target);
                $("#flowType").combobox('setValue', pnode.id);
                $("#node_id").val(node.id);
                $("#node_text").val(node.text);
                console.debug(node.id);
                console.debug(node.text);          
            }
        })

HTML构建:

1
2
3
<ulid="tt1">
             
        </ul>

启动TOMCAT预览就可以看到一个树形图的效果了!

关注公众号,分享干货,讨论技术

EasyUI Tree递归方式获取JSON的更多相关文章

  1. MVC4中EasyUI Tree异步加载JSON数据生成树

      1,首先构造tree接受的格式化数据结构MODEL /// <summary> /// 定义EasyUI树的相关数据,方便控制器生成Json数据进行传递 /// </summar ...

  2. 用递归方式在JSON中查找对象

    Json文件例子: { "type": "Update", "data": { "temp": "v" ...

  3. 树状sql--采用递归方式获取节点

    创建数据库 create table City(id varchar(3) primary key , pid varchar(3) , name varchar(10)) 插入数据 insert i ...

  4. jQuery AJAX获取JSON数据解析多种方式示例

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  5. J2EE Web开发入门—通过action是以传统方式返回JSON数据

    关键字:maven.m2eclipse.JSON.Struts2.Log4j2.tomcat.jdk7.Config Browser Plugin Created by Bob 20131031 l ...

  6. AngularJS学习笔记(3)——通过Ajax获取JSON数据

    通过Ajax获取JSON数据 以我之前写的与用户交互的动态清单列表为例,使用JSON前todo.html代码如下: <!DOCTYPE html> <html ng-app=&quo ...

  7. C++通过HTTP请求Get或Post方式请求Json数据(转)

    原文网址:https://www.cnblogs.com/shike8080/articles/6549339.html #pragma once#include <iostream>#i ...

  8. ajax获取json数据为undefined--原因解析

    解决办法:var dataObj=eval("("+data+")");//转换为json对象 问题: 1. 碰到一个问题ajax成功获取json数据后,取值显 ...

  9. [转]easyui tree 模仿ztree 使用扁平化加载json

    原文地址:http://my.oschina.net/acitiviti/blog/349377 参考文章:http://www.jeasyuicn.com/demo/treeloadfilter.h ...

随机推荐

  1. Docker学习笔记总结

    Docker学习笔记 https://yeasy.gitbooks.io/docker_practice/content/   一 环境搭建 Ubuntu安装 .添加软件源的GPG密钥 curl -f ...

  2. codeforces 228E The Road to Berland is Paved With Good Intentions(2-SAT)

    Berland has n cities, some of them are connected by bidirectional roads. For each road we know wheth ...

  3. ZOJ 2760 How Many Shortest Path(最短路径+最大流)

    Description Given a weighted directed graph, we define the shortest path as the path who has the sma ...

  4. 如何做好FAE工作及FAE职位发展

    此文较长,是作者对于半导体FAE职业的一些总结,码字不容易,耐心的阅读,欢迎点赞. 曾经认识一位做电源研发的工程师,转行在一家代理商做FAE,做了一年半以后,就提出了离职请求,他老板问他是什么原因,他 ...

  5. PAT 甲级 1128 N Queens Puzzle

    https://pintia.cn/problem-sets/994805342720868352/problems/994805348915855360 The "eight queens ...

  6. 【Linux】- apt-get命令

    apt-get,是一条linux命令,适用于deb包管理式的操作系统,主要用于自动从互联网的软件仓库中搜索.安装.升级.卸载软件或操作系统. Advanced Package Tool,又名apt-g ...

  7. css边框以及其他常用样式

    1. 边框是1像素,实体的,红色的. <!DOCTYPE html> <html lang="en"> <head> <meta char ...

  8. html的body内标签之input系列2

    一,input系列:name属性用于让后台拿数据.value 只是在屏幕上的显示. 1. input type='text' name='query' value="张三"(相当于 ...

  9. Oracle 以某字段分组,以某字段排序,取前几条

    select * from (select row_number() over(partition by 以此字段为分组  order by 以此字段排序 desc rn from dual) whe ...

  10. 对于iOS性能优化的一点看法

    在我们通常的开发工作中,每次需求定下来的时候,开发时间都是很紧张的,于是我们就抓紧时间开发,完成需求.在匆忙开发的过程中,或多或少的会有一些性能问题存在,在开发任务完成以后,我们都要进行性能优化.现将 ...