最近在作權限功能的時候,採用的ztree實現的,可是產品要求最後一層的權限節點要橫向顯示。開始在網上找的解決方案是用css樣式把最後一層的display設置爲inline。在我本地電腦上看了下。效果不錯。css
可是,後來測試在用十年前的筆記本測這個功能的時候,發現特別的卡,致使瀏覽器都崩潰了。因此,性能優化開始了。瀏覽器
一、同步改成異步,雖然不卡,可是功能不知足,不少人勾選了一個父節點(模塊節點),就保存,此時子節點根本沒有,因此保存的數據是有問題的。性能優化
二、設置showIcon和showLine爲false,發現速度有一丟丟的提高,可是產品仍是不滿意。數據結構
三、仔細看了下,ztree的checkbox都是用span模擬的,搞個背景圖。憑直覺以爲用原生的checkbox要比用圖片模擬要強一些。說幹就幹,找了ztree提供的一個例子,稍做改造,效果仍是很明顯的。用到的主要方法時addDiyDom。異步
下面把主要的代碼貼上來。性能
一、數據結構,要求有一個isLeaf節點,標記是不是子節點。測試
var zNodes =[ { id:1, pId:0, name:"父節點 1", open:true,isLeaf:false}, { id:11, pId:1, name:"葉子節點 1-1",isLeaf:true}, { id:12, pId:1, name:"葉子節點 1-2",open:true,isLeaf:false}, { id:120, pId:12, name:"葉子節點 1-2-0",isLeaf:true}, { id:121, pId:12, name:"葉子節點 1-2-1",isLeaf:true}, { id:13, pId:1, name:"葉子節點 1-3",isLeaf:true}, { id:2, pId:0, name:"父節點 2", open:true,isLeaf:false}, { id:21, pId:2, name:"葉子節點 2-1",isLeaf:true}, { id:22, pId:2, name:"葉子節點 2-2",isLeaf:true}, { id:23, pId:2, name:"葉子節點 2-3",isLeaf:true}, { id:3, pId:0, name:"父節點 3", open:true,isLeaf:false}, { id:31, pId:3, name:"葉子節點 3-1",isLeaf:true}, { id:32, pId:3, name:"葉子節點 3-2",isLeaf:true}, { id:33, pId:3, name:"葉子節點 3-3",isLeaf:true} ];
二、addDiyDom方法優化
function addDiyDom(treeId, treeNode) { //console.log(treeNode); var aObj = $("#" + treeNode.tId + IDMark_A); var editStr = $("<input type='checkbox' class='checkboxBtn' id='checkbox_" +treeNode.id+ "' onclick='checkedHandler(this)' ></input>"); editStr.data("treeNode",treeNode); aObj.before(editStr); }
三、本身寫的幾個級聯操做的方法this
function checkedHandler(checkbox){ var $checkbox = $(checkbox), treeNode = $checkbox.data("treeNode"), state = checkbox.checked; if(treeNode.isLeaf){ //子節點 if(state){ //子節點選中,父節點要跟着選中,子節點取消選擇,父節點不用級聯 setParentNodeChecked(checkbox); } }else{ //父節點 if(state){ //選中,級聯子節點,級聯父節點 setParentNodeChecked(checkbox); setChildNodeChecked(checkbox); }else{ setChildNodeChecked(checkbox); } } } /**設置父節點選中 */ function setParentNodeChecked(checkbox){ var $pNode = $(checkbox).closest("ul").parent(); var pCheckbox = $pNode.find(".checkboxBtn").get(0); var treeNode = $(pCheckbox).data("treeNode"); if(pCheckbox.checked === checkbox.checked) return;if(treeNode.pId != "0"){
pCheckbox.checked = checkbox;
setParentNodeChecked(pCheckbox);
} } /**設置子節點選中 */ function setChildNodeChecked(checkbox){ $(checkbox).closest("li").find(".checkboxBtn").each(function(){ this.checked = checkbox.checked; }); }
四、css中,設置:spa
.ztree li.isLeaf{
display:inline;
}
要想看實際效果,請訪問:http://runjs.cn/detail/jz9f31qr