国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

ztree實現權限橫向顯示功能

2019-11-19 16:32:29
字體:
來源:轉載
供稿:網友

 最近在做權限功能的時候,采用的ztree實現的,但是產品要求最后一層的權限節點要橫向顯示。開始在網上找的解決方案是用css樣式把最后一層的display設置為inline。在我本地電腦上看了下。效果不錯。

但是,后來測試在用十年前的筆記本測這個功能的時候,發現特別的卡,導致瀏覽器都崩潰了。所以,性能優化開始了。

1、同步改為異步,雖然不卡,但是功能不滿足,很多人勾選了一個父節點(模塊節點),就保存,此時子節點根本沒有,所以保存的數據是有問題的。

2、設置showIcon和showLine為false,發現速度有一丟丟的提升,但是產品還是不滿意。

3、仔細看了下,ztree的checkbox都是用span模擬的,搞個背景圖。憑直覺覺得用原生的checkbox要比用圖片模擬要強一些。說干就干,找了ztree提供的一個例子,稍作改造,效果還是很明顯的。用到的主要方法時addDiyDom。

下面把主要的代碼貼上來。

1、數據結構,要求有一個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}    ];

2、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);        }

3、自己寫的幾個級聯操作的方法

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;      pCheckbox.checked = checkbox;      if(treeNode.pId != "0") setParentNodeChecked(pCheckbox);    }    /**設置子節點選中 */    function setChildNodeChecked(checkbox){      $(checkbox).closest("li").find(".checkboxBtn").each(function(){        this.checked = checkbox.checked;      });    }

4、css中,設置:

.ztree li.isLeaf{  display:inline; }

以上所述是小編給大家介紹的ztree實現權限橫向顯示功能,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的,在此也非常感謝大家對武林網網站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 晋州市| 许昌县| 宁南县| 宝应县| 五寨县| 班戈县| 饶阳县| 剑川县| 阿尔山市| 安康市| 灵台县| 两当县| 大港区| 揭阳市| 冷水江市| 乌苏市| 榆林市| 咸宁市| 隆昌县| 平潭县| 泊头市| 巴青县| 禄劝| 大田县| 嘉善县| 聂拉木县| 龙泉市| 靖江市| 清河县| 涿州市| 澄城县| 丹凤县| 江华| 外汇| 乐都县| 宁远县| 永康市| 屏南县| 苏尼特右旗| 万盛区| 东乡族自治县|