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封装的textarea操作方法集合(兼容很好)
Nov 16 Javascript
JS 控制小数位数的实现代码
Aug 02 Javascript
jquery 实现上下滚动效果示例代码
Aug 09 Javascript
JavaScript显示当然日期和时间即年月日星期和时间
Oct 29 Javascript
封装好的javascript前端分页插件pagination
Jan 04 Javascript
Javascript的表单验证-揭开正则表达式的面纱
Mar 18 Javascript
JS中input表单隐藏域及其使用方法
Feb 13 Javascript
详解AngularJS ng-class样式切换
Jun 27 Javascript
JS字符串常用操作方法实例小结
Jun 24 Javascript
vue draggable resizable 实现可拖拽缩放的组件功能
Jul 15 Javascript
jQuery Raty星级评分插件使用方法实例分析
Nov 25 jQuery
OpenLayers3实现地图显示功能
Sep 25 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
PHP Directory 函数的详解
2013/03/07 PHP
PHP has encountered a Stack overflow问题解决方法
2014/11/03 PHP
PHP实现检测客户端是否使用代理服务器及其匿名级别
2015/01/07 PHP
PHP7.0版本备注
2015/07/23 PHP
php版交通银行网银支付接口开发入门教程
2016/09/26 PHP
php 从一个数组中随机的取出若干个不同的数实例
2016/12/31 PHP
PHP使用ActiveMQ实现消息队列的方法详解
2019/05/31 PHP
JavaScript 异步调用框架 (Part 3 - 代码实现)
2009/08/04 Javascript
javascript 快速排序函数代码
2012/05/30 Javascript
jQuery之过滤元素操作小结
2013/11/30 Javascript
Javascript监视变量变化的方法
2015/06/09 Javascript
BootStrap便签页的简单应用
2017/01/06 Javascript
jQuery实现鼠标跟随效果
2017/02/20 Javascript
Node.js中.pfx后缀文件的处理方法
2017/03/10 Javascript
详解node HTTP请求客户端 - Request
2017/05/05 Javascript
jQuery EasyUI Layout实现tabs标签的实例
2017/09/26 jQuery
微信小程序实现漂亮的弹窗效果
2020/05/26 Javascript
详解vue页面首次加载缓慢原因及解决方案
2019/11/06 Javascript
JS禁用右键、禁用Ctrl+u、禁用Ctrl+s、禁用F12的实现代码
2020/12/01 Javascript
Python入门_浅谈for循环、while循环
2017/05/16 Python
Python字符串中删除特定字符的方法
2020/01/15 Python
python 的topk算法实例
2020/04/02 Python
python3.7调试的实例方法
2020/07/21 Python
HTML5标签大全
2016/11/23 HTML / CSS
意大利领先的奢侈品在线时装零售商:MCLABELS
2020/10/13 全球购物
公司薪酬管理制度
2014/01/31 职场文书
小学教师师德感言
2014/02/10 职场文书
销售助理岗位职责
2014/02/21 职场文书
公务员政审个人鉴定
2014/02/25 职场文书
眼镜促销方案
2014/03/15 职场文书
招商引资工作汇报材料
2014/10/28 职场文书
行政主管岗位职责
2015/02/03 职场文书
2016年大学生暑假爱心支教活动策划书
2015/11/26 职场文书
2016年保险公众宣传日活动总结
2016/04/05 职场文书
导游词之徐州-云龙山
2019/09/29 职场文书
Python爬虫之爬取哔哩哔哩热门视频排行榜
2021/04/28 Python