关于combotree的用法总结
后台:
实体树
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的用法总结的更多相关文章
- easyui 之ComboTree 用法Demo
实现效果如下: HTML部分: <html xmlns="http://www.w3.org/1999/xhtml"> <head runat="ser ...
- Easyui主要组件用法
Easyui主要组件用法说明: 1. combogrid用法 说明:combogrid可提供翻页列表的数据选择并可进行数据的过滤查询(查询的传人参数为q,可在控制器中获取这个参数传过来的值,下面的示 ...
- EasyUI –tree、combotree学习总结
EasyUI –tree.combotree学习总结 一. tree总结 (一).tree基本使用 tree控件是web页面中将数据分层一树形结构显示的. 使用$.fn.tree.defaults ...
- 表单(上)EasyUI Form 表单、EasyUI Validatebox 验证框、EasyUI Combobox 组合框、EasyUI Combo 组合、EasyUI Combotree 组合树
EasyUI Form 表单 通过 $.fn.form.defaults 重写默认的 defaults. 表单(form)提供多种方法来执行带有表单字段的动作,比如 ajax 提交.加载.清除,等等. ...
- EditText 基本用法
title: EditText 基本用法 tags: EditText,编辑框,输入框 --- EditText介绍: EditText 在开发中也是经常用到的控件,也是一个比较必要的组件,可以说它是 ...
- jquery插件的用法之cookie 插件
一.使用cookie 插件 插件官方网站下载地址:http://plugins.jquery.com/cookie/ cookie 插件的用法比较简单,直接粘贴下面代码示例: //生成一个cookie ...
- Java中的Socket的用法
Java中的Socket的用法 Java中的Socket分为普通的Socket和NioSocket. 普通Socket的用法 Java中的 ...
- [转载]C#中MessageBox.Show用法以及VB.NET中MsgBox用法
一.C#中MessageBox.Show用法 MessageBox.Show (String) 显示具有指定文本的消息框. 由 .NET Compact Framework 支持. MessageBo ...
- python enumerate 用法
A new built-in function, enumerate() , will make certain loops a bit clearer. enumerate(thing) , whe ...
随机推荐
- position relative
position的默认值是static,(也就是说对于任意一个元素,如果没有定义它的position属性,那么它的position:static) 如果你想让这个#demo里的一个div#sub相对于 ...
- dev 中的GridControl中的行实现选择的功能实现
1.项目有实现不GridControl中的数据导出Excel的功能,导出的时候是把所有的数据全部导出,现在要实现可供选择的灵活的导出功能.除了全选可全不选,还可以对每一行实现选择的功能.实现起来比较简 ...
- Python之路- 反射&定制自己的数据类型
一.isinstance和issubclass isinstance(obj,cls)检查是否obj是否是类 cls 的对象 issubclass(sub, super)检查sub类是否是 super ...
- mui开发app之多图压缩与上传(仿qq空间说说发表)
欲实现效果图 提出需求点: 用户可自由添加删除替换多张图片,并且显示相应缩略图,限制为8张 用户可选择压缩图或直接上传原图功能 返回提醒用户会丢失填写的信息 下面一个个实现上述需求,从简单到复杂: 需 ...
- 浅谈JavaScript匿名函数与闭包
一. 匿名函数 //普通函数定义: //单独的匿名函数是无法运行的.就算运行了,也无法调用,因为没有名称. 如: function(){ alert('123'); ...
- 蓝桥杯-打印大X-java
/* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2016, 广州科技贸易职业学院信息工程系学生 * All rights reserved. * 文件名称: ...
- Quartz (一)
1 核心接口 1.1 Scheduler---核心调度器 1.2 Job---任务 1.3 JobDetail---任务描述 1.4 Trigger---触发器 2 触发器 Tigger(CornTr ...
- yum 安装redis 及简单命令(推荐测试环境,安装简单)
第1章 redis 入门 1.1 yum 安装 安装repo源 cd /etc/yum.repos.d/ wget http://mirrors.aliyun.com/repo/epel-6.repo ...
- hdu2717Catch That Cow 简单BFS
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2717 刚开始思路错了,用的DP,一直WA,后来才发现是搜索,还是简单的BFS,顿时.... 思路: B ...
- 回锅的美食:JSP+EL+JSTL大杂烩汤
title: Servlet之JSP tags: [] notebook: javaWEB --- JSP是什么 ? JSP就是Servlet,全名是"JavaServer Pages&qu ...