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 相关文章推荐
Prototype使用指南之range.js
Jan 10 Javascript
用dtree实现树形菜单 dtree使用说明
Oct 17 Javascript
jQuery实现为控件添加水印文字效果(附源码)
Dec 02 Javascript
JavaScript比较当前时间是否在指定时间段内的方法
Aug 02 Javascript
JS表单提交验证、input(type=number) 去三角 刷新验证码
Jun 21 Javascript
使用vuex的state状态对象的5种方式
Apr 19 Javascript
详解VS Code使用之Vue工程配置format代码格式化
Mar 20 Javascript
使用Vue-cli3.0创建的项目 如何发布npm包
Oct 10 Javascript
js实现数字滚动特效
Dec 16 Javascript
javascript 函数的暂停和恢复实例详解
Apr 25 Javascript
vue实现购物车列表
Jun 30 Javascript
Vue Element校验validate的实例
Sep 21 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字符串截取问题
2006/11/28 PHP
Yii数据读取与跳转参数传递用法实例分析
2016/07/12 PHP
jquery拖拽排序简单实现方法(效果增强版)
2016/02/16 Javascript
Ajax+FormData+javascript实现无刷新表单信息提交
2016/10/24 Javascript
angular双向绑定模拟探索
2016/12/26 Javascript
JavaScript解析JSON格式数据的方法示例
2017/01/24 Javascript
js中less常用的方法小结
2017/08/09 Javascript
vuex 动态注册方法 registerModule的实现
2019/07/03 Javascript
vue父子模板传值问题解决方法案例分析
2020/02/26 Javascript
Python实现的Excel文件读写类
2015/07/30 Python
神经网络理论基础及Python实现详解
2017/12/15 Python
python DataFrame 修改列的顺序实例
2018/04/10 Python
Python学习笔记之open()函数打开文件路径报错问题
2018/04/28 Python
Python走楼梯问题解决方法示例
2018/07/25 Python
10 行 Python 代码教你自动发送短信(不想回复工作邮件妙招)
2018/10/11 Python
Python使用tkinter模块实现推箱子游戏
2019/10/08 Python
opencv3/C++图像像素操作详解
2019/12/10 Python
Python面向对象之私有属性和私有方法应用案例分析
2019/12/31 Python
基于keras输出中间层结果的2种实现方式
2020/01/24 Python
python GUI库图形界面开发之PyQt5多行文本框控件QTextEdit详细使用方法实例
2020/02/28 Python
基于Python绘制个人足迹地图
2020/06/01 Python
Python xlrd模块导入过程及常用操作
2020/06/10 Python
python对execl 处理操作代码
2020/06/22 Python
解决Python 函数声明先后顺序出现的问题
2020/09/02 Python
工厂采购员岗位职责
2014/04/08 职场文书
大学开学计划书
2014/04/30 职场文书
小学优秀教育工作者事迹材料
2014/05/09 职场文书
机械专业技术员求职信
2014/06/14 职场文书
专题组织生活会方案
2014/06/15 职场文书
咖啡厅商业计划书
2014/09/15 职场文书
实习协议书范本
2014/09/25 职场文书
基层干部个人对照检查及整改措施
2014/10/28 职场文书
2016教师给学生的毕业寄语
2015/12/04 职场文书
银行柜员工作心得体会
2016/01/23 职场文书
写给医护人员的一封感谢信
2019/09/16 职场文书
导游词之山西关帝庙
2019/11/01 职场文书