一、初始异步加载树
初始化默认给出一个根结点,再结合异步加载的方式手动触发默认加载第一层,如图:
代码如下:
var TreeSetting={ async : { enable : true,a href=' http://my。奥希娜。net/wee pan/admin/' XXX/demo。做什么?方法=listByTree ' rel=' no follow ' URL : ' XXX/demo。做什么?method=listByTree/a ',dataType:'json ',autoParam:['id=pid'] },view : { dblclickeexpandd : true,selectedMulti: false,expandspeed :($)。浏览器。msie解析器($。浏览器。版本)=6)?'fast' },数据: { simple data : { enable : true,idKey: 'id ',pIdKey: 'pid ',rootPId: 'root' },回调: { onnodeceated d 3360 ztreeonodecaded } };//默认根结点var rootNode={'id':0,' pid':'root ',' name': '商品分类,' open':true,' isParent ' : true };$(文档)。ready(function(){ var ztreeObj=$。fn。ztree。init($(' # tree ')、treeSetting、rootNode);var node=ZtreeObj。GetNodeByParam(' id ',0,null);zTreeObj.reAsyncChildNodes(节点,'刷新');});二、异步搜索叶子结点
在使用JQuery ZTREE时可能要用到异步的方式模糊搜索叶子结点,如图:
而如果只使用ZTREE自带的展开方法zTreeObj.expandNode只是会展开改结点,无法触发异步加载;这时候就必须手动调用异步加载的方法进行处理,解决思路如下:通过在其他参数数组中设值的方式将搜索参数带到后台(无参数时必须将其他参数设为空数组否则一直会将前一次的参数带到后台);在结点创建完成后的回调函数无创建中进行手动异步加载。
代码如下:
函数searchM() { var param=$ .修剪($('input[name='param']').val());var treeObj=$。fn。ztree。getztreeObj('树');var node=TreeObj。GetNodeByParam(' id ',0,null);if(param!=' '){ param=encodeURI(encodeURI(param));treeObj。设置。异步。其他参数=[' param ',param];}else { //搜索参数为空时必须将参数数组设为空treeObj。设置。异步。其他参数=[];} treeObj.reAsyncChildNodes(节点,"刷新");}函数zTreeOnNodeCreated(event,treeId,TreeNode){ var param span/span span/span=$ .tr span/span m($(' input[name=' param ']').val());var treeObj=$。fn。ztree。getztreeObj('树');//只有搜索参数不为空且该节点为父节点时才进行异步加载if(param!=' ' treeNode。isparent){ treeObj。reasyncchildnodes(treeNode,‘refresh’);} };更多关于ztree控件的内容,请参考专题《jQuery插件ztree使用汇总》 。
以上就是关于jquery ztree异步搜索的全部内容,希望对大家的学习有所帮助。