jQuery zTree 异步加载添加子节点重复问题


Posted in jQuery onNovember 29, 2017

zTree 简介

    zTree 是一个依靠 jQuery 实现的多功能 “树插件”。优异的性能、灵活的配置、多种功能的组合是 zTree 最大优点。

    zTree 是开源免费的软件(MIT 许可证)。如果您对 zTree 感兴趣或者愿意资助 zTree 继续发展下去,可以进行捐助。

  • zTree v3.0 将核心代码按照功能进行了分割,不需要的代码可以不用加载
  • 采用了 延迟加载 技术,上万节点轻松加载,即使在 IE6 下也能基本做到秒杀
  • 兼容 IE、FireFox、Chrome、Opera、Safari 等浏览器
  • 支持 JSON 数据
  • 支持静态 和 Ajax 异步加载节点数据
  • 支持任意更换皮肤 / 自定义图标(依靠css)
  • 支持极其灵活的 checkbox 或 radio 选择功能
  • 提供多种事件响应回调
  • 灵活的编辑(增/删/改/查)功能,可随意拖拽节点,还可以多节点拖拽哟
  • 在一个页面内可同时生成多个 Tree 实例
  • 简单的参数配置实现 灵活多变的功能

原始问题

//添加结点, 产品和版本
function addNode(event) {
  rMenu.css({ "visibility": "hidden" });
  var treeNode = zTree.getSelectedNodes()[0];
  var pid;
  var nodeName;
  var treelevel;
  if (!treeNode && event.target.tagName.toLowerCase() != "button" && $(event.target).parents("a").length == 0) {
   //添加产品结点
pid = 0;
   treeNode = null;
   treelevel = 1;
  } else if (treeNode) {
   //添加版本结点
pid = treeNode.id;
  treelevel = 2;
  }
  $.post(
   "AddNode.action",
   { type: treelevel, id: pid },
   function(nodeIdAndName) {
    var params = /([^\|]+)\|([^\|]+)/.exec(nodeIdAndName);
    if (!((!treeNode && event.target.tagName.toLowerCase() != "button" && $(event.target).parents("a").length == 0) || treeNode.open)) {
     zTree.expandNode(treeNode, true);
    }
    treeNode = zTree.addNodes(treeNode, { id: params[1], pid: pid, isParent: "true", name: params[2], editable: "true", treelevel: treelevel });
   });
}

原本直接添加子节点的时候,如果父节点没有展开,会添加两个一样的子节点(第一次的时候);后来我对父节点是否展开进行了判断,但是却变成了如果父节点展开,会添加两个一样的子节点(第一次的时候),这个问题要怎么解决呢?

办法一 

if (!((!treeNode && event.target.tagName.toLowerCase() != "button" && $(event.target).parents("a").length == 0) || treeNode.open)) {
     zTree.expandNode(treeNode, true);
    }
    treeNode = zTree.addNodes(treeNode, { id: params[1], pid: pid, isParent: "true", name: params[2], editable: "true", treelevel: treelevel });

改成

if(!treeNode && event.target.tagName.toLowerCase() != "button" && $(event.target).parents("a").length == 0)
    {
     treeNode = zTree.addNodes(treeNode, { id: params[1], pid: pid, isParent: "true", name: params[2], editable: "true", treelevel: treelevel });
    }
    else if(treeNode.open)
    {
     if(treeNode.isParent)
     {
      zTree.reAsyncChildNodes(treeNode, "refresh");
     }
     else
     {
      treeNode.isParent=true;
      zTree.reAsyncChildNodes(treeNode, "refresh");
     }
    }
    else
    {
     zTree.expandNode(treeNode, true);
     treeNode = zTree.addNodes(treeNode, { id: params[1], pid: pid, isParent: "true", name: params[2], editable: "true", treelevel: treelevel });
    }

问题就可以解决了,但是有没有优化呢?感觉改后的代码分类太多了 

最优办法

貌似不用这么麻烦吧?前两天回答了类似的问题。

1、点击添加子节点后,就直接 ajax 传给后台保存数据,捕获 success 事件

2、ajax success 时,利用 treeNode.zAsync 属性就可以知道此父节点是否进行过异步加载,如果为 false 那么直接 reAsyncChildNodes 刷新, 如果为 true 那么利用 addN...

if ((!treeNode && event.target.tagName.toLowerCase() != "button" && $(event.target).parents("a").length == 0) || treeNode.zAsync) 
     treeNode = zTree.addNodes(treeNode, { id: params[1], pid: pid, isParent: "true", name: params[2], editable: "true", treelevel: treelevel });
    else
     zTree.reAsyncChildNodes(treeNode, "refresh");

总结

以上所述是小编给大家介绍的jQuery zTree 异步加载添加子节点重复问题,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

jQuery 相关文章推荐
jQuery输入框密码的显示隐藏【代码分享】
Apr 29 jQuery
jQuery.ajax向后台传递数组问题的解决方法
May 12 jQuery
jQuery选择器_动力节点Java学院整理
Jul 05 jQuery
jQuery常见面试题之DOM操作详析
Jul 05 jQuery
基于jquery的on和click的区别详解
Jan 15 jQuery
jQuery AJAX 方法success()后台传来的4种数据详解
Aug 08 jQuery
jQuery模拟12306城市选择框功能简单实现方法示例
Aug 13 jQuery
jQuery pjax 应用简单示例
Sep 20 jQuery
jQuery+css last-child实现选择最后一个子元素操作示例
Dec 10 jQuery
使vue实现jQuery调用的两种方法
May 12 jQuery
JQuery插件tablesorter表格排序实现过程解析
May 28 jQuery
jQuery实现带进度条的轮播图
Sep 13 jQuery
jQuery图片加载失败替换默认图片方法汇总
Nov 29 #jQuery
jquery animate动画持续运动的实例
Nov 29 #jQuery
JQuery 又谈ajax局部刷新
Nov 27 #jQuery
jQuery Datatables表头不对齐的解决办法
Nov 27 #jQuery
javaScript和jQuery自动加载简单代码实现方法
Nov 24 #jQuery
jquery实现回车键触发事件(实例讲解)
Nov 21 #jQuery
jQuery实现所有验证通过方可提交的表单验证
Nov 21 #jQuery
You might like
Zend Studio (eclipse)使用速度优化方法
2011/03/23 PHP
php常用的安全过滤函数集锦
2014/10/09 PHP
php实现对两个数组进行减法操作的方法
2015/04/17 PHP
PHP模糊查询的实现方法(推荐)
2016/09/06 PHP
PHPCMS忘记后台密码的解决办法
2016/10/30 PHP
PHP那些琐碎的知识点(整理)
2017/05/20 PHP
PHP中如何使用Redis接管文件存储Session详解
2018/11/28 PHP
基于Jquery的动态创建DOM元素的代码
2010/12/28 Javascript
javascript实现div的拖动并调整大小类似qq空间个性编辑模块
2012/12/12 Javascript
javascript移出节点removeChild()使用介绍
2014/04/03 Javascript
用jquery实现的一个超级简单的下拉菜单
2014/05/18 Javascript
jquery通过closest选择器修改上级元素的方法
2015/03/17 Javascript
javascript字符串与数组转换汇总
2015/05/26 Javascript
js实现简洁的TAB滑动门效果代码
2015/09/06 Javascript
第七章之菜单按钮图标组件
2016/04/25 Javascript
基于Bootstrap实现tab标签切换效果
2020/04/15 Javascript
Jquery遍历select option和添加移除option的实现方法
2016/08/26 Javascript
easyui datebox 时间限制,datebox开始时间限制结束时间,datebox截止日期比起始日期大的实现代码
2017/01/12 Javascript
基于bootstrap页面渲染的问题解决方法
2018/08/09 Javascript
使用pm2自动化部署node项目的方法步骤
2019/01/28 Javascript
ES6中定义类和对象的方法示例
2019/07/31 Javascript
JS异步宏队列与微队列原理区别详解
2020/07/02 Javascript
[03:05]《我与DAC》之xiao8:DAC与BG
2018/03/27 DOTA
python2.7到3.x迁移指南
2018/02/01 Python
Python合并同一个文件夹下所有PDF文件的方法
2019/03/11 Python
python实现ip代理池功能示例
2019/07/05 Python
使用coverage统计python web项目代码覆盖率的方法详解
2019/08/05 Python
Python对Excel按列值筛选并拆分表格到多个文件的代码
2019/11/05 Python
tensorflow 初始化未初始化的变量实例
2020/02/06 Python
Python astype(np.float)函数使用方法解析
2020/06/08 Python
施工安全生产承诺书
2014/05/23 职场文书
党员群众路线对照检查材料
2014/08/31 职场文书
勿忘国耻9.18演讲稿(经典篇)
2014/09/14 职场文书
2014年学校食堂工作总结
2014/11/25 职场文书
红灯733-1型14管5波段半导体收音机
2021/04/22 无线电
Java异常体系非正常停止和分类
2022/06/14 Java/Android