jquery ztree异步搜索

一、初始异步加载树

    初始化默认给出一个根结点,再结合异步加载的方式手动触发默认加载第一层,如图:

代码如下:
复制代码
var treeSetting = {
  async: {
  enable: true, url:"xxx/demo.do?method=listByTree",
  dataType:"json",
  autoParam:["id=pid"]
  },
  view: {
  dblClickExpand: true,
  selectedMulti: false,
  expandSpeed: ($.browser.msie && parseInt($.browser.version)<=6)?"":"fast"
  },
  data: {
    simpleData: {
      enable:true,
      idKey: "id",
      pIdKey: "pid",
      rootPId: "root"
    }
  },
  callback: {
    onNodeCreated: zTreeOnNodeCreated
  }
};

//默认根结点
var rootNode = {"id":0, "pid":"root", "name":"商品分类", "open":true, "isParent":true};

$(document).ready(function(){
  var zTreeObj = $.fn.zTree.init($("#tree"), treeSetting, rootNode);
  var node = zTreeObj.getNodeByParam("id", 0, null);
  zTreeObj.reAsyncChildNodes(node, "refresh");
});
复制代码

二、异步搜索叶子结点

    在使用JQuery ZTREE时可能要用到异步的方式模糊搜索叶子结点,如图:

    而如果只使用ZTREE自带的展开方法zTreeObj.expandNode只是会展开改结点,无法触发异步加载;这时候就必须手动调用异步加载的方法进行处理,解决思路如下:    
    通过在otherParam数组中设值的方式将搜索参数带到后台(无参数时必须将otherParam设为空数组否则一直会将前一次的参数带到后台);在结点创建完成后的回调函数onNodeCreated中进行手动异步加载。

代码如下:

复制代码
function searchM() {
  var param = $.trim($("input[name='param']").val());
  var treeObj = $.fn.zTree.getZTreeObj("tree");
  var node = treeObj.getNodeByParam("id", 0, null);
  if(param != ""){
    param = encodeURI(encodeURI(param));
    treeObj.setting.async.otherParam=["param", param];
  }else {
    //搜索参数为空时必须将参数数组设为空
    treeObj.setting.async.otherParam=[];
  }
  treeObj.reAsyncChildNodes(node, "refresh");
}

function zTreeOnNodeCreated(event, treeId, treeNode) {
  var param = $.trim($("input[name='param']").val());
  var treeObj = $.fn.zTree.getZTreeObj("tree");
  //只有搜索参数不为空且该节点为父节点时才进行异步加载
  if(param != "" && treeNode.isParent){
    treeObj.reAsyncChildNodes(treeNode, "refresh");
  } 
};
复制代码

 

posted @   岁月淡忘了谁  阅读(3698)  评论(3编辑  收藏  举报
(评论功能已被禁用)
编辑推荐:
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)
点击右上角即可分享
微信分享提示