Easyui 异步树的实现
网上最多的onBeforeExpand 可用,因为后台代码没写对导致树形结构重复加载数据
前端代码:
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<div>
<table cellpadding="5">
<tr>
<td height="300px"><ul id="diseaseNameTree" class="easyui-tree"></ul>
</td>
</tr>
</table>
</div>
<script>
$('#diseaseNameTree').tree({
url : getServer_context() + '/api/patient/getDiseaseNameTree?Id=',
onBeforeExpand : function(node, param) {
console.log('ID=' + node.id);
console.log('length=' + node.id.length);
$('#diseaseNameTree').tree('options').url = getServer_context() + '/api/patient/getDiseaseNameTree?Id=' + node.id;
}
}) function searchICD10ByPinyin() {
var pinyin = $('#ICD10Pinyin').val();
console.log(pinyin);
if (pinyin == null || pinyin == "") {
$('#diseaseNameTree').tree('reload');
} else {
console.log('000');
$('#diseaseNameTree').tree({
url: getServer_context() + '/api/patient/getDiseaseNameByPinyin?Pinyin=' + pinyin
});
} }
</script>
后台代码:
     public JSONArray getDiseaseNameTreeData(String Id) throws RecordNotFoundException {
         JSONArray jsonArray = new JSONArray();
         JSONArray childrenArray = new JSONArray();
         JSONArray grandChildrenArray = new JSONArray();
         JSONObject parentObject = new JSONObject();
         JSONObject childrenObject = new JSONObject();
         JSONObject grandChildrenObject = new JSONObject();
         if(Id == null || "".equals(Id)) {
             Iterable<SsIcd10> parentList = ssICD10Dao.getDiseaseNameParent();
             for(SsIcd10 parent : parentList) {
                 parentObject.clear();
                 parentObject.put("id", parent.getFicd10());
                 parentObject.put("text", parent.getFdesc());
                 parentObject.put("state", "closed");
                 jsonArray.add(parentObject);
             }
             return jsonArray;
         } else if (Id.length() == 3){
             Iterable<SsIcd10> childrenList = ssICD10Dao.gettDiseaseNameChildren(Id);
             for(SsIcd10 child : childrenList) {
                 childrenObject.clear();
                 childrenObject.put("id", child.getFicd10());
                 childrenObject.put("text", child.getFdesc());
                 childrenObject.put("state", ssICD10Dao.hasGrandChildren(child.getFicd10()) > 0 ? "closed" : "open");
                 childrenArray.add(childrenObject);
             }
             return childrenArray;
         } else {
             Iterable<SsIcd10> grandChildrenList = ssICD10Dao.gettDiseaseNameGrandChildren(Id);
             for(SsIcd10 grandChild : grandChildrenList) {
                 grandChildrenObject.clear();
                 grandChildrenObject.put("id", grandChild.getFicd10());
                 grandChildrenObject.put("text", grandChild.getFdesc());
                 grandChildrenArray.add(grandChildrenObject);
             }
             return grandChildrenArray;
         }
逻辑写的很傻,还没想出来怎么写更好的
     public JSONArray getDiseaseNameTreeByPinyin(String Pinyin) throws RecordNotFoundException {
         JSONArray jsonArray = new JSONArray();
         JSONArray childrenArray = new JSONArray();
         JSONArray grandChildrenArray = new JSONArray();
         JSONObject parentObject = new JSONObject();
         JSONObject childrenObject = new JSONObject();
         JSONObject grandChildrenObject = new JSONObject();
         Iterable<SsIcd10> list = ssICD10Dao.getDiseaseNameDataByPinyin(Pinyin);
         for(SsIcd10 ssIcd10 : list) {
             if(ssIcd10.getFicd10().length() == 3) {
                 parentObject.clear();
                 parentObject.put("id", ssIcd10.getFicd10());
                 parentObject.put("text", ssIcd10.getFdesc());
                 Iterable<SsIcd10> children =  ssICD10Dao.getDiseaseNameChildrenByPinyin(ssIcd10.getFicd10(), Pinyin);
                 if(children != null) {
                     childrenArray.clear();
                     for(SsIcd10 child : children) {
                         childrenObject.clear();
                         childrenObject.put("id", child.getFicd10());
                         childrenObject.put("text", child.getFdesc());
                         Iterable<SsIcd10> grandChildren = ssICD10Dao.getDiseaseNameGrandChildrenByPinyin(child.getFicd10(), Pinyin);
                         if(grandChildren != null) {
                             grandChildrenArray.clear();
                             for(SsIcd10 grandChild : grandChildren) {
                                 grandChildrenObject.clear();
                                 grandChildrenObject.put("id", grandChild.getFicd10());
                                 grandChildrenObject.put("text", grandChild.getFdesc());
                                 grandChildrenArray.add(grandChildrenObject);
                             }
                             childrenObject.put("children", grandChildrenArray);
                         }
                         childrenArray.add(childrenObject);
                     }
                     parentObject.put("children", childrenArray);
                 }
                 jsonArray.add(parentObject);
             } else if (ssIcd10.getFicd10().length() > 3 && ssIcd10.getFicd10().length() <= 6) {
                 if(ssICD10Dao.hasParent(ssIcd10.getFicd10().substring(0, 3), Pinyin) == 0) {
                     parentObject.clear();
                     parentObject.put("id", ssIcd10.getFicd10());
                     parentObject.put("text", ssIcd10.getFdesc());
                     Iterable<SsIcd10> grandChildren = ssICD10Dao.getDiseaseNameGrandChildrenByPinyin(ssIcd10.getFicd10(), Pinyin);
                     if(grandChildren != null) {
                         grandChildrenArray.clear();
                         for(SsIcd10 grandChild : grandChildren) {
                             grandChildrenObject.clear();
                             grandChildrenObject.put("id", grandChild.getFicd10());
                             grandChildrenObject.put("text", grandChild.getFdesc());
                             grandChildrenArray.add(grandChildrenObject);
                         }
                         parentObject.put("children", grandChildrenArray);
                     }
                     jsonArray.add(parentObject);
                 }
             } else {
                 if(ssICD10Dao.hasParent(ssIcd10.getFicd10().substring(0, 3), Pinyin) == 0
                         && ssICD10Dao.hasChildren(ssIcd10.getFicd10().substring(0, 6), Pinyin) == 0) {
                     parentObject.clear();
                     parentObject.put("id", ssIcd10.getFicd10());
                     parentObject.put("text", ssIcd10.getFdesc());
                     jsonArray.add(parentObject);
                 }
             }
         }
         return jsonArray;
     }
Easyui 异步树的实现的更多相关文章
- Easyui 异步树直接所有展开
		初始化异步树直接所有展开代码: $(function(){ $('#tt').tree({ url:'<%=request.getContextPath()%>/treeInit', li ... 
- EasyUI的功能树之异步树
		最近几个项目都用到了EasyUI这个Jquery框架,目前感觉起来还是很好使的,展示效果很好,帮助文档什么的资料很多,而且互联网上Easy粉很多,大多数拥护和喜爱EasyUI的粉丝们都愿意在网络平台互 ... 
- EasyUI tree 异步树与采用扁平化实现的同步树
		所谓好记性不如烂笔头,为了以防忘记,才写下这篇博客,废话不多.. 异步树: tips: 可以采用easyui里的原始数据格式,也可以采用扁平化的数据格式. 使用场景: 当菜单模块数量庞大或者无限极 ... 
- 数据网格和树-EasyUI Datagrid 数据网格、EasyUI Propertygrid 属性网格、EasyUI Tree 树、EasyUI Treegrid 树形网格
		EasyUI Datagrid 数据网格 扩展自 $.fn.panel.defaults.通过 $.fn.datagrid.defaults 重写默认的 defaults. 数据网格(datagrid ... 
- 基于MVC4+EasyUI的Web开发框架经验总结(2)- 使用EasyUI的树控件构建Web界面
		最近花了不少时间在重构和进一步提炼我的Web开发框架上,力求在用户体验和界面设计方面,和Winform开发框架保持一致,而在Web上,我主要采用EasyUI的前端界面处理技术,走MVC的技术路线,在重 ... 
- 使用EasyUI的树控件构建Web界面
		最近花了不少时间在重构和进一步提炼我的Web开发框架上,力求在用户体验和界面设计方面,和Winform开发框架保持一致,而在Web上,我主要采用EasyUI的前端界面处理技术,走MVC的技术路线,在重 ... 
- easyui 获取树的平级根节点的父节点&选择性展示树的一个根节点
		1.easyui的树的根节点一般是几个平级的,怎样获取这些父节点的id? 可以将获取到的平级根节点放在一个数组中 var roots=[]; roots=$("#tree1").t ... 
- EasyUI Tree 树
		转自:http://www.jeasyui.net/plugins/185.html 通过 $.fn.tree.defaults 重写默认的 defaults. 树(tree)在网页中以树形结构显示分 ... 
- (转)基于MVC4+EasyUI的Web开发框架经验总结(2)- 使用EasyUI的树控件构建Web界面
		http://www.cnblogs.com/wuhuacong/p/3669575.html 最近花了不少时间在重构和进一步提炼我的Web开发框架上,力求在用户体验和界面设计方面,和Winform开 ... 
随机推荐
- MVVM简介
			如果你对MVVM的概念还是不了解,可以参看下面链接:http://baike.baidu.com/view/3507915.htm 我们以WPF+MVVM的本地桌面程序为背景,这样一来我们可以不去操心 ... 
- 【POJ2886】Who Gets the Most Candies?-线段树+反素数
			Time Limit: 5000MS Memory Limit: 131072K Case Time Limit: 2000MS Description N children are sitting ... 
- 解析xml并且导入mysql
			https://www.zhihu.com/question/28139319 解析超过500G的xml 写入mysql,如何尽快写入? 解析超过500G的xml 写入mysql,如何尽快写入? 现在 ... 
- Excel 2007 批量删除隐藏的文本框
			该方法取自百度知道,该朋友给出函数,我详细写一下方法. 打开有文本框的excel文件. 按 Alt+F11 打开编辑器. 将下面的函数复制进去: Sub deltxbox()Dim s As Shap ... 
- Ubuntu 16.04 LTS 安装 Nginx/PHP 5.6/MySQL 5.7 (LNMP) 与Laravel
			Ubuntu 16.04 LTS 安装 Nginx/PHP 5.6/MySQL 5.7 (LNMP) 与Laravel 1.MySQL安装[安装 MariaDB]MariaDB是MySQL的一个分支首 ... 
- SqlServer  递归查询树形数据
			一直没有在意过数据库处理树形数据的重要性,直到有一天朋友问起我关于树形数据查询的问题时才发现根本不会,正好这个时候也要用到递归进行树形数据的查询于是在网上查了一圈,语法总结如下 参考文献:https: ... 
- 微信小程序-地图组件
			map 地图. 标记点 标记点用于在地图上显示标记的位置,不能自定义图标和样式 覆盖物 覆盖物用于在地图上显示自定义图标,可自定义图标和样式 地图组件的经纬度必填, 如果不填经纬度则默认值是北京的经纬 ... 
- SpringMVC生成Excel下载
			SpringMVC controller里的方法: @RequestMapping(value="/notify/download",produces = {"appli ... 
- Django + mysql 快速搭建简单web投票系统
			了解学习pyhton web的简单demo 1. 安装Django, 安装pyhton 自行百度 2. 执行命令创建project django-admin.py startproject mysi ... 
- 1012. The Best Rank (25)
			To evaluate the performance of our first year CS majored students, we consider their grades of three ... 
