(转载),有个坑记录下:
(原文)实现类似下面这种:
/** * 展开树 * @param treeId */ function expand_ztree(treeId) { var treeObj = $.fn.zTree.getZTreeObj(treeId); treeObj.expandAll(true); } /** * 收起树:只展开根节点下的一级节点 * @param treeId */ function close_ztree(treeId) { var treeObj = $.fn.zTree.getZTreeObj(treeId); var nodes = treeObj.transformToArray(treeObj.getNodes()); console.log(JSON.stringify(nodes)); var nodeLength = nodes.length; for (var i = 0; i < nodeLength; i++) { //console.log(nodes[i].id); if (nodes[i].id == '0') { //console.log('根节点:展开'+JSON.stringify(nodes[i])); //根节点:展开 treeObj.expandNode(nodes[i], true, true, false); } else { //非根节点:收起 //console.log('非根节点:收起'+JSON.stringify(nodes[i])); treeObj.expandNode(nodes[i], false, true, false); } } } /** * 搜索树,高亮显示并展示【模糊匹配搜索条件的节点s】 * @param treeId * @param searchConditionId 文本框的id */ function search_ztree(treeId, searchConditionId) { searchByFlag_ztree(treeId, searchConditionId, ""); } /** * 搜索树,高亮显示并展示【模糊匹配搜索条件的节点s】 * @param treeId * @param searchConditionId 搜索条件Id * @param flag 需要高亮显示的节点标识 */ function searchByFlag_ztree(treeId, searchConditionId, flag) { //<1>.搜索条件 var searchCondition = $('#' + searchConditionId).val().trim(); //<2>.得到模糊匹配搜索条件的节点数组集合 var highlightNodes = new Array(); if (searchCondition != "") { var treeObj = $.fn.zTree.getZTreeObj(treeId); highlightNodes = treeObj.getNodesByParamFuzzy("name", searchCondition, null); } //<3>.高亮显示并展示【指定节点s】 highlightAndExpand_ztree(treeId, highlightNodes, flag); } /** * 高亮显示并展示【指定节点s】 * @param treeId * @param highlightNodes 需要高亮显示的节点数组 * @param flag 需要高亮显示的节点标识 */ function highlightAndExpand_ztree(treeId, highlightNodes, flag) { var treeObj = $.fn.zTree.getZTreeObj(treeId); //<1>. 先把全部节点更新为普通样式 var treeNodes = treeObj.transformToArray(treeObj.getNodes()); for (var i = 0; i < treeNodes.length; i++) { treeNodes[i].highlight = false; treeObj.updateNode(treeNodes[i]); } //<2>.收起树, 只展开根节点下的一级节点 close_ztree(treeId); //<3>.把指定节点的样式更新为高亮显示,并展开 if (highlightNodes != null) { for (var i = 0; i < highlightNodes.length; i++) { if (flag != null && flag != "") { if (highlightNodes[i].flag == flag) { //高亮显示节点,并展开 highlightNodes[i].highlight = true; treeObj.updateNode(highlightNodes[i]); //高亮显示节点的父节点的父节点....直到根节点,并展示 var parentNode = highlightNodes[i].getParentNode(); var parentNodes = getParentNodes_ztree(treeId, parentNode); treeObj.expandNode(parentNodes, true, false, true); treeObj.expandNode(parentNode, true, false, true); } } else { //高亮显示节点,并展开 highlightNodes[i].highlight = true; treeObj.updateNode(highlightNodes[i]); //高亮显示节点的父节点的父节点....直到根节点,并展示 var parentNode = highlightNodes[i].getParentNode(); var parentNodes = getParentNodes_ztree(treeId, parentNode); treeObj.expandNode(parentNodes, true, false, true); treeObj.expandNode(parentNode, true, false, true); } } } } /** * 递归得到指定节点的父节点的父节点....直到根节点 */ function getParentNodes_ztree(treeId, node) { if (node != null) { var treeObj = $.fn.zTree.getZTreeObj(treeId); var parentNode = node.getParentNode(); return getParentNodes_ztree(treeId, parentNode); } else { return node; } } /** * 设置树节点字体样式 */ function setFontCss_ztree(treeId, treeNode) { if (treeNode.id == 0) { //根节点 return {color: "#333", "font-weight": "500"}; } else if (treeNode.isParent == false) { //叶子节点 return (!!treeNode.highlight) ? {color: "#ff0000", "font-weight": "bold"} : { color: "#660099", "font-weight": "normal" }; } else { //父节点 return (!!treeNode.highlight) ? {color: "#ff0000", "font-weight": "bold"} : { color: "#333", "font-weight": "normal" }; } }
说明:
1、 setFontCss_ztree
是在 zTree的配置开头定义setting的时候使用:
view: { showIcon: false, selectedMulti: false, nameIsHTML: true, fontCss: setFontCss_ztree },
2、 使用的时候注意 在 close_ztree
方法里:
if (nodes[i].id == '0') { //根节点:展开 treeObj.expandNode(nodes[i], true, true, false); } else { //非根节点:收起 treeObj.expandNode(nodes[i], false, true, false); }
这里的 nodes[i].id == ‘0’ 是判断数据中的根节点的id为0的,如果搜索的时候无法正常展开/收缩,或者错位问题,请检查根节点的id是否为0,如果使用的数据格式没有id=0的根节点,请把条件修改成判断根节点的条件。
来源:https://www.cnblogs.com/rysinal/p/5834445.html