zTree 是一個依靠 jQuery 實現(xiàn)的多功能 “樹插件”。優(yōu)異的性能、靈活的配置、多種功能的組合是 zTree 最大優(yōu)點。
我們是成立于2013年的成都網(wǎng)站建設(shè)公司,提供網(wǎng)站建設(shè),電商網(wǎng)站設(shè)計開發(fā),成都外貿(mào)網(wǎng)站建設(shè),響應(yīng)式網(wǎng)頁設(shè)計,小程序開發(fā)、等服務(wù)。為客戶創(chuàng)造有價值的品牌營銷體驗,讓互聯(lián)網(wǎng)提升企業(yè)的競爭力!
上篇文章給大家介紹了vue中如何使用ztree,大家可以點擊查看。
之前博客介紹過怎么在vue里展示以及獲取點擊元素的內(nèi)容,此文章之介紹搜索功能
html
main.js需要單獨引入
import "./../static/ztree/js/jquery.ztree.exhide-3.5.min.js";
如果不單獨引入這個會獲取不到很多元素,在input回車事件或者點擊事件的時候直接執(zhí)行此事件即可
代碼部分
expand_ztree(treeId) { var treeObj = $.fn.zTree.getZTreeObj(treeId); treeObj.expandAll(true); }, close_ztree(treeId) { var treeObj = $.fn.zTree.getZTreeObj(treeId); var nodes = treeObj.transformToArray(treeObj.getNodes()); var nodeLength = nodes.length; for (var i = 0; i < nodeLength; i++) { if (nodes[i].id == '0') { //根節(jié)點:展開 treeObj.expandNode(nodes[i], true, true, false); } else { //非根節(jié)點:收起 treeObj.expandNode(nodes[i], false, true, false); } } }, search_ztree(treeId, searchConditionId) { this.searchByFlag_ztree(treeId, searchConditionId, ""); }, searchByFlag_ztree(treeId, searchConditionId, flag) { //<1>.搜索條件 var searchCondition = $('#' + searchConditionId).val(); //<2>.得到模糊匹配搜索條件的節(jié)點數(shù)組集合 var highlightNodes = new Array(); if (searchCondition != "") { var treeObj = $.fn.zTree.getZTreeObj(treeId); highlightNodes = treeObj.getNodesByParamFuzzy("name", searchCondition, null); } //<3>.高亮顯示并展示【指定節(jié)點s】 this.highlightAndExpand_ztree(treeId, highlightNodes, searchCondition, flag); }, highlightAndExpand_ztree(treeId, highlightNodes, tx, flag) { var treeObj = $.fn.zTree.getZTreeObj(treeId); //<1>. 先把全部節(jié)點更新為普通樣式 var treeNodes = treeObj.transformToArray(treeObj.getNodes()); for (var i = 0; i < treeNodes.length; i++) { treeNodes[i].highlight = false; treeObj.updateNode(treeNodes[i]); } //<2>.收起樹, 只展開根節(jié)點下的一級節(jié)點 this.close_ztree(treeId); //<3>.把指定節(jié)點的樣式更新為高亮顯示,并展開 if (highlightNodes != null) { for (var i = 0; i < highlightNodes.length; i++) { if (flag != null && flag != "") { if (highlightNodes[i].flag == flag) { //高亮顯示節(jié)點,并展開 highlightNodes[i].highlight = true; treeObj.updateNode(highlightNodes[i]); //高亮顯示節(jié)點的父節(jié)點的父節(jié)點....直到根節(jié)點,并展示 var parentNode = highlightNodes[i].getParentNode(); var parentNodes = this.getParentNodes_ztree(treeId, parentNode); treeObj.expandNode(parentNodes, true, false, true); treeObj.expandNode(parentNode, true, false, true); } } else { treeObj.updateNode(highlightNodes[i]); var parentNode = highlightNodes[i].getParentNode(); var parentNodes = this.getParentNodes_ztree(treeId, parentNode); treeObj.expandNode(parentNodes, true, false, true); treeObj.expandNode(parentNode, true, false, true); } } } }, getParentNodes_ztree(treeId, node) { if (node != null) { var treeObj = $.fn.zTree.getZTreeObj(treeId); var parentNode = node.getParentNode(); return this.getParentNodes_ztree(treeId, parentNode); } else { return node; } }
展示
http://weahome.cn/article/jscjis.html