Jquery zTree 树控件异步加载操作


Posted in Javascript onFebruary 25, 2016

zTree 是利用 JQuery 的核心代码,实现一套能完成大部分常用功能的 Tree 插件

  • 兼容 IE、FireFox、Chrome 等浏览器
  • 在一个页面内可同时生成多个 Tree 实例
  • 支持 JSON 数据
  • 支持一次性静态生成 和 Ajax 异步加载 两种方式
  • 支持多种事件响应及反馈
  • 支持 Tree 的节点移动、编辑、删除
  • 支持任意更换皮肤 / 个性化图标(依靠css)
  • 支持极其灵活的 checkbox 或 radio 选择功能
  • 简单的参数配置实现 灵活多变的功能

Jquery zTree 树控件异步加载操作

异步加载的意思就是: 当点击展开树节点时,才去请求后台action返回点击节点的子节点数据并加载。

这里面主要设计ztree的setting变量的async属性设置:

var setting = {
 async: {
  enable: true,
  url:InitServiceIpsData.action,
  autoParam:[id, name],
  dataFilter: filter 
 },

当点击展开树节点时,会请求url指定的action获取子节点数据,然后绑定到ztree上。

注意这里后台action返回的是JSON字符串,而ztree绑定新的节点数据只接收数组,所以需要在绑定前用filter函数进行数据清洗转换操作,将字符串转换为数组:

//过滤异步加载ztree时返回的数据 
 function filter(treeId, parentNode, childNodes) {
 if (!childNodes) 
  return null; 
 childNodes = eval((+childNodes+)); //必须转换为[{id:103,pId:1,name:'子节点3'}];这样的格式 
 return childNodes;
 }

这样点击展开ztree树节点时,就会请求action获取子节点数据并绑定了。 

下面是后台action的一个实现:

public String InitServiceIpsData()
 {
 HttpServletRequest request = ServletActionContext.getRequest();
 String id = request.getParameter(id);
 String name = request.getParameter(name);
 System.out.println(请求获取+name+的ip列表);
  
 List<hashmap<string,object>> list = new ArrayList<hashmap<string,object>>();  
 for(int i = 1; i <= 2; i++){ 
  HashMap<string,object> hm = new HashMap<string,object>();  
  hm.put(id, id + 0 + i);
  hm.put(pId, id);
  hm.put(name, name + _IP_ + i);
  hm.put(isParent, false);
  list.add(hm);
 } 
  
 JSONArray finalJson = JSONArray.fromObject(list);
 this.initServiceIpsData = finalJson.toString();
 return SUCCESS;
 }</string,object></string,object></hashmap<string,object></hashmap<string,object>

更多关于ztree控件的内容,请参考专题《jQuery插件ztree使用汇总》

以上就是Jquery zTree 树控件实现异步加载操作的详细步骤,希望对大家的学习有所帮助。

Javascript 相关文章推荐
js操作ajax返回的json的注意问题!
Feb 23 Javascript
js将字符串转成正则表达式的实现方法
Nov 13 Javascript
Ajax请求在数据量大的时候出现超时的解决方法
Feb 27 Javascript
JavaScript模拟深蓝vs卡斯帕罗夫的国际象棋对局示例
Apr 22 Javascript
JS字符串长度判断,超出进行自动截取的实例(支持中文)
Mar 06 Javascript
Angular.js初始化之ng-app的自动绑定与手动绑定详解
Jul 31 Javascript
laydate 显示结束时间不小于开始时间的实例
Aug 11 Javascript
Angularjs中数据绑定的实例详解
Aug 25 Javascript
JS实现多物体运动的方法详解
Jan 23 Javascript
JS高阶函数原理与用法实例分析
Jan 15 Javascript
Vue实现push数组并删除的例子
Nov 01 Javascript
vue在线动态切换主题色方案
Mar 26 Javascript
jquery插件jquery.dragscale.js实现拖拽改变元素大小的方法(附demo源码下载)
Feb 25 #Javascript
js判断图片加载完成后获取图片实际宽高的方法
Feb 25 #Javascript
JS面向对象(3)之Object类,静态属性,闭包,私有属性, call和apply的使用,继承的三种实现方法
Feb 25 #Javascript
jquery zTree异步加载简单实例讲解
Feb 25 #Javascript
JavaScript代码因逗号不规范导致IE不兼容的问题
Feb 25 #Javascript
jquery插件jquery.LightBox.js实现点击放大图片并左右点击切换效果(附demo源码下载)
Feb 25 #Javascript
JQuery ztree带筛选、异步加载实例讲解
Feb 25 #Javascript
You might like
Zend Framework实现将session存储在memcache中的方法
2016/03/22 PHP
PHP超级全局变量【$GLOBALS,$_SERVER,$_REQUEST等】用法实例分析
2019/12/11 PHP
PHP实现文件上传操作和封装
2020/03/04 PHP
js时间日期和毫秒的相互转换
2013/02/22 Javascript
JQUERY 设置SELECT选中项代码
2014/02/07 Javascript
jquery.ajax之beforeSend方法使用介绍
2014/12/08 Javascript
javascript委托(Delegate)blur和focus用法实例分析
2015/05/26 Javascript
搭建Bootstrap离线文档的方法
2016/12/02 Javascript
利用原生JS与jQuery实现数字线性变化的动画
2017/02/24 Javascript
Web开发中客户端的跳转与服务器端的跳转的区别
2017/03/05 Javascript
js实现悬浮窗效果(支持拖动)
2017/03/09 Javascript
代码详解Vuejs响应式原理
2017/12/20 Javascript
jquery中ajax请求后台数据成功后既不执行success也不执行error的完美解决方法
2017/12/24 jQuery
微信小程序实现多选功能
2018/11/04 Javascript
layui表格数据重载
2019/07/27 Javascript
使用Bootstrap做一个朝代历史表
2019/12/10 Javascript
微信小程序8种数据通信的方式小结
2020/02/03 Javascript
JavaScript Blob对象原理及用法详解
2020/10/14 Javascript
win10环境下python3.5安装步骤图文教程
2017/02/03 Python
详解python实现读取邮件数据并下载附件的实例
2017/08/03 Python
Python+树莓派+YOLO打造一款人工智能照相机
2018/01/02 Python
tensorflow 中对数组元素的操作方法
2018/07/27 Python
python实现beta分布概率密度函数的方法
2019/07/08 Python
如何爬取通过ajax加载数据的网站
2019/08/15 Python
python递归函数求n的阶乘,优缺点及递归次数设置方式
2020/04/02 Python
如何使用PyCharm将代码上传到GitHub上(图文详解)
2020/04/27 Python
python 如何用urllib与服务端交互(发送和接收数据)
2021/03/04 Python
美国网上花店:JustFlowers
2017/02/12 全球购物
世界排名第一的运动鞋市场:Flight Club
2020/01/03 全球购物
土木工程求职信
2014/05/29 职场文书
建筑安全标语
2014/06/07 职场文书
2014年新教师工作总结
2014/11/08 职场文书
文员岗位职责
2015/02/04 职场文书
运动会广播稿200字
2015/08/19 职场文书
用Python写一个简易版弹球游戏
2021/04/13 Python
JavaScript架构localStorage特殊场景下二次封装操作
2022/06/21 Javascript