后台:

    实体树

    public class TreeNode{

      private String id;
      private String text;
      private String level;
      private List<LogTypeTreeNode> children = new ArrayList<>();
      public LogTypeTreeNode(String id, String text, String level){
            this.id = id;
            this.text = text;
            this.level = level;
         }

      //get()、set()

    }

    形成展示成的树的结构,需用到递归

    public List<TreeNode> getTree() {
            List<Map<String, Object>> list = sieveLogService.getEventType();

        //获取所有数据需包含(PARENT_ID 父id(PARENT_ID=-1说明是根节点),TYPE_ID 节点id,TYPE_NAME节点名称,TREE_LEVEL 树层级数)
            List<TreeNode> allNode = new ArrayList<TreeNode>();// 存放所有节点的集合
            for (Map<String, Object> map : list) {
                if (MapUtils.getString(map, "PARENT_ID").equals("-1")) {
                    TreeNode tn = new TreeNode(MapUtils.getString(map, "TYPE_ID"),
                               MapUtils.getString(map, "TYPE_NAME"), MapUtils.getString(map, "TREE_LEVEL"));
                    allNode.add(tn);
                }
            }
            for (LogTypeTreeNode root : allNode) {
                  bulidTreeNode(root, list);
            }
            return allNode;
      }

    private TreeNode bulidTreeNode(TreeNode tn, List<Map<String, Object>> list) {
            for (Map<String, Object> map : list) {
                if (MapUtils.getString(map, "PARENT_ID").equals(tn.getId())) {
                    TreeNode tnChild = new TreeNode(MapUtils.getString(map, "TYPE_ID"),
                            MapUtils.getString(map, "EVENT_TYPE_NAME"), MapUtils.getString(map, "TREE_LEVEL"));
                    tn.addChildNode(tnChild);
                    bulidTreeNode(tnChild, list);
                }
            }
            return tn;
      }

    前台:

    <input type="checkbox" class="easyui-combotree"
                                                    data-options="multiple:true" style="width: 300px;"    id="id"  />

    用ajax获取即可展示:

    $.ajax({
              url : "/.../getTree",
              dataType : "JSON",
              success : function(data) {
                  $('#id').combotree('loadData', data);        //当数据展示为undefind时,可用 $('#id').combotree('loadData', eval(data));       
              }
          });

    获取选中的树:1.只能获取节点id:var logType = $("#id").combotree("getValues");

           2.获取到树节点:var t = $('#operationType').combotree('tree'); // 得到树对象
                          var node = t.tree('getChecked', [ 'checked', 'indeterminate' ]); // 得到选择的节点

                  循环node.length,node[i].level:树层级数,node[i].id:节点id,node[i].text:节点名称

    编辑时回显选中树节点:

      后台:把id值拼成以逗号隔开的字符串,在前台以el表达式接收到<input  type="hidden" id="allType" value="${allType}" />

      前台:在以上加载完树之后

          $.ajax({
                    url : "/.../getTree",
                    dataType : "JSON",
                    success : function(data) {
                        $('#id').combotree('loadData', data);        //当数据展示为undefind时,可用 $('#id').combotree('loadData', eval(data));

              //编辑时显示打上对勾
                          var at = $("#allType").val().split(",");                   
                          $('#id').combotree('setValues', at);    
                    }
                });

     设置树的下拉面板的宽度:

      $("#id").combotree({

         panelWidth:200,

         panelHeight:200

      )};

    (还有另外加载的树的方法总结,请持续关注)

关于combotree的用法总结的更多相关文章

  1. easyui 之ComboTree 用法Demo

    实现效果如下: HTML部分: <html xmlns="http://www.w3.org/1999/xhtml"> <head runat="ser ...

  2. Easyui主要组件用法

    Easyui主要组件用法说明: 1.  combogrid用法 说明:combogrid可提供翻页列表的数据选择并可进行数据的过滤查询(查询的传人参数为q,可在控制器中获取这个参数传过来的值,下面的示 ...

  3. EasyUI –tree、combotree学习总结

    EasyUI –tree.combotree学习总结 一.   tree总结 (一).tree基本使用 tree控件是web页面中将数据分层一树形结构显示的. 使用$.fn.tree.defaults ...

  4. 表单(上)EasyUI Form 表单、EasyUI Validatebox 验证框、EasyUI Combobox 组合框、EasyUI Combo 组合、EasyUI Combotree 组合树

    EasyUI Form 表单 通过 $.fn.form.defaults 重写默认的 defaults. 表单(form)提供多种方法来执行带有表单字段的动作,比如 ajax 提交.加载.清除,等等. ...

  5. EditText 基本用法

    title: EditText 基本用法 tags: EditText,编辑框,输入框 --- EditText介绍: EditText 在开发中也是经常用到的控件,也是一个比较必要的组件,可以说它是 ...

  6. jquery插件的用法之cookie 插件

    一.使用cookie 插件 插件官方网站下载地址:http://plugins.jquery.com/cookie/ cookie 插件的用法比较简单,直接粘贴下面代码示例: //生成一个cookie ...

  7. Java中的Socket的用法

                                   Java中的Socket的用法 Java中的Socket分为普通的Socket和NioSocket. 普通Socket的用法 Java中的 ...

  8. [转载]C#中MessageBox.Show用法以及VB.NET中MsgBox用法

    一.C#中MessageBox.Show用法 MessageBox.Show (String) 显示具有指定文本的消息框. 由 .NET Compact Framework 支持. MessageBo ...

  9. python enumerate 用法

    A new built-in function, enumerate() , will make certain loops a bit clearer. enumerate(thing) , whe ...

随机推荐

  1. TCP/IP笔记(七)TCP详解

    TCP的特点及其目的 为了通过数据包实现可靠性传输,需要考虑很多事情,例如数据的破坏.丢包.重复记忆分片顺序混乱等问题.如不能解决这些问题,也就无从谈起可靠传输. TCP通过检验和.序列号.确认应答. ...

  2. Eclipse 安装反编译插件

    前言:在实际的开发中几乎都会使用到一些框架来辅助项目的开发工作,对于一些框架的代码我们总怀有一些好奇之心,想一探究竟,有源码当然更好了,对于有些JAR包中的代码我们就需要利用反编译工具来看一下了,下面 ...

  3. php 启动过程 - reqeust RSHUTDOWN 过程

    php 启动过程 - reqeust RSHUTDOWN 过程 概述 request RSHUTDOWN 过程在请求结束后调用 调用触发 同 request RINIT 过程一样, 先是用 apach ...

  4. JavaEE开发之SpringMVC中的自定义拦截器及异常处理

    上篇博客我们聊了<JavaEE开发之SpringMVC中的路由配置及参数传递详解>,本篇博客我们就聊一下自定义拦截器的实现.以及使用ModelAndView对象将Controller的值加 ...

  5. Extjs6组件——Form大家族成员介绍

    本文基于ext-6.0.0 一.xtype form一共有12种xtype,下面来一一举例说一下. 1.textfield 这个是用的最多的form之一. { xtype: 'textfield', ...

  6. 做一个常规的banner图——负边距的使用、banner图的拼法

    在这之前,首先要了解如何设置块级元素在块级元素水平居中 方法: 设置子容器为定位元素 水平居中 left:50%:margin-left:-width/2: 垂直居中 top:50%:margin-t ...

  7. IE报vuex requires a Promise polyfill in this browser问题解决

    使用Vuex, IE浏览器报错 因为使用了 ES6 中用来传递异步消息的的Promise,而IE低版本的浏览器不支持. ##解决方法 第一步: 安装 babel-polyfill . babel-po ...

  8. session知识总结

    0.什么是会话? - 简单理解:打开浏览器到关闭浏览器过程中的操作.请求. 1.Session是什么? - session是HttpSession的简称: - 用于保存会话状态: - 将会话状态保存在 ...

  9. ST-1之乱码bug

    我印象最深刻的一个错误就是乱码.上学期末做web期末作业时候,我就遇到了好多乱码问题.乱码问题并不是程序本身的逻辑错误,但是却让程序的可用性非常的差.只有输入英文时才能判断结果的正确与否.而且编译器又 ...

  10. 重庆/北京/江苏KS/快乐时时/七星/福运来菠菜电商开奖修复APP网站SSC网站程序开发php

    网站制作是指使用标识语言(markup language),通过一系列设计.建模.和执行的过程将电子格式的信息通过互联网传输,最终以图形用户界面(GUI)的形式被用户所浏览.简单来说,网页设计的目的就 ...