jquery ztree异步搜索(搜叶子)实践

前端之家收集整理的这篇文章主要介绍了jquery ztree异步搜索(搜叶子)实践前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

一、初始异步加载树

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

代码如下:

",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",null);
zTreeObj.reAsyncChildNodes(node,"refresh");
});

二、异步搜索叶子结点

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

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

代码如下:

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");
}
};

更多关于ztree控件的内容,请参考专题

以上就是关于jquery ztree异步搜索的全部内容,希望对大家的学习有所帮助。

猜你在找的jQuery相关文章