关于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 ...
随机推荐
- C#,VB.NET 如何将Excel转换为Text
在工作中,有时我们需要转换文档的格式,之前已经跟大家介绍过了如何将Excel转换为PDF.今天将与大家分享如何将Excel转换为Text.这次我使用的依然是免费版的Spire.XLS for .NET ...
- const常量类型
1.定义:const常量类型表示一个”常值变量“,其值是不能被修改的变量.即一旦变量被声明为const类型,编译器将禁止任何试图修改该变量的操作. 2.声明:const <声明数据类型> ...
- java上转型和下转型(对象的多态性)
/*上转型和下转型(对象的多态性) *上转型:是子类对象由父类引用,格式:parent p=new son *也就是说,想要上转型的前提必须是有继承关系的两个类. *在调用方法的时候,上转型对象只能调 ...
- IT行业能力细分
在软件行业工作7年了,平时很懒,懒得做分享,今天特意分享一下软件行业,职业大的技术分类,同学们可根据自己职业规划补充学习知识块.
- split()方法
split()方法用于把一个字符串分隔成字符串数组. 它有两个参数: separator:从参数指定的地方分隔字符串,必需: howmany:该参数可指定返回的数组的最大长度.如果设置了该参数,返回的 ...
- [进程管理] 理解 Linux 的处理器负载均值
原文链接: http://blog.scoutapp.com/articles/2009/07/31/understanding-load-averages http://www.gracecode. ...
- 【转】QQ传输文件原理参考(来自互联网)
QQ的文件发送是怎样的过程呢?通常,发送文件的计算机首先要通过消息服务器将其IP地址发送给接收计算机,当接收计算机同意接收的确认消息反馈到消息服务器后,消息服务器将据此设置好文件传输对话.随即,发送计 ...
- office web apps 部署-搭建域控服务器
开始第一条先说注意事项:我所配置的环境是用了三台2012server虚拟机,三台虚拟机必须要加下域控,而且登录操作的时候必须以域账号登录,否则测试不通过!在笔记本上搭建了两个虚拟机(window se ...
- Java常用API解析——序列化API
原创作品,可以转载,但是请标注出处地址:http://www.cnblogs.com/V1haoge/p/6797659.html 工作中发现,自己对Java的了解还很片面,没有深入的研究,有很多的J ...
- Webgis开源解决方案之环境搭建(三)
前两篇文章介绍了开源GIS服务器Geoserver的安装以及开源数据库Postgres的安装,这篇文章介绍开源前端udig软件的安装,使用在后续篇幅中介绍 开源前端目前主流的是QGIS或者udig,网 ...