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 相关文章推荐
jquery导航制件jquery鼠标经过变色效果示例
Dec 05 Javascript
javascript实现数字验证码的简单实例
Feb 10 Javascript
jQuery性能优化的38个建议
Mar 04 Javascript
js在指定位置增加节点函数insertBefore()用法实例
Jan 12 Javascript
JavaScript 变量、作用域及内存
Apr 08 Javascript
JQuery+CSS实现图片上放置按钮的方法
May 29 Javascript
Bootstrap中的fileinput 多图片上传及编辑功能
Sep 05 Javascript
对象不支持indexOf属性或方法的解决方法(必看)
May 28 Javascript
Vue仿手机qq的实例代码(demo)
Sep 08 Javascript
vue项目常用组件和框架结构介绍
Dec 24 Javascript
vue-cli3 项目优化之通过 node 自动生成组件模板 generate View、Component
Apr 30 Javascript
基于JS实现视频上传显示进度条
May 12 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各种编码集详解和以及在什么情况下进行使用
2011/09/11 PHP
PHP中的替代语法介绍
2015/01/09 PHP
php用ini_get获取php.ini里变量值的方法
2015/03/04 PHP
Extjs gridpanel 出现横向滚动条问题的解决方法
2011/07/04 Javascript
ASP.NET jQuery 实例5 (显示CheckBoxList成员选中的内容)
2012/01/13 Javascript
Jquery uploadify图片上传插件无法上传的解决方法
2013/12/16 Javascript
jquery处理json对象
2014/11/03 Javascript
jQuery实现的背景动态变化导航菜单效果
2015/08/24 Javascript
AngularJS HTML DOM详解及示例代码
2016/08/17 Javascript
Angular中使用ui router实现系统权限控制及开发遇到问题
2016/09/23 Javascript
ionic2 tabs使用 Modal底部tab弹出框
2016/12/30 Javascript
js实现固定宽高滑动轮播图效果
2017/01/13 Javascript
three.js实现围绕某物体旋转
2017/01/25 Javascript
JS中SetTimeout和SetInterval使用初探
2017/03/23 Javascript
微信小程序图片选择、上传到服务器、预览(PHP)实现实例
2017/05/11 Javascript
微信小程序组件之srcoll-view的详解
2017/10/19 Javascript
javascript修改浏览器title方法 JS动态修改浏览器标题
2017/11/30 Javascript
JS双向链表实现与使用方法示例(增加一个previous属性实现)
2019/01/31 Javascript
Vue实现表格批量审核功能实例代码
2019/05/28 Javascript
在Vue mounted方法中使用data变量详解
2019/11/05 Javascript
vue实现网络图片瀑布流 + 下拉刷新 + 上拉加载更多(步骤详解)
2020/01/14 Javascript
Vue组件基础用法详解
2020/02/05 Javascript
js与jquery获取input输入框中的值实例讲解
2020/02/27 jQuery
vue页面跳转实现页面缓存操作
2020/07/22 Javascript
vue封装自定义指令之动态显示title操作(溢出显示,不溢出不显示)
2020/11/12 Javascript
CentOS下使用yum安装python-pip失败的完美解决方法
2017/08/16 Python
Django基础知识与基本应用入门教程
2018/07/20 Python
基于python-opencv3的图像显示和保存操作
2019/06/27 Python
python提取log文件内容并画出图表
2019/07/08 Python
Python并发concurrent.futures和asyncio实例
2020/05/04 Python
Python的scikit-image模块实例讲解
2020/12/30 Python
英国最大的LED专业零售商:Led Hut
2018/03/16 全球购物
标记环介质访问控制协议
2016/03/27 面试题
幼儿园教师获奖感言
2014/03/11 职场文书
2019学生会干事辞职信
2019/06/27 职场文书
SQL Server Agent 服务无法启动
2022/04/20 SQL Server