首頁 >web前端 >js教程 >ztree實作權限橫向顯示功能實例分享

ztree實作權限橫向顯示功能實例分享

小云云
小云云原創
2018-01-11 14:00:382029瀏覽

最近在做權限功能的時候,採用的ztree實現的,但是產品要求最後一層的權限節點要橫向顯示。以下小編把基於ztree實作權限橫向顯示功能的實作想法分享給大家,供大家參考,希望能幫助大家。

 最近在做權限功能的時候,所採用的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=&#39;checkbox&#39; class=&#39;checkboxBtn&#39; id=&#39;checkbox_" +treeNode.id+ "&#39; onclick=&#39;checkedHandler(this)&#39; ></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;
 }

相關推薦:

##實例詳解jQuery EasyUI結合zTree樹形結構製作web頁面

zTree非同步載入展開第一級節點方法實作

##實例解譯jQuery使用zTree外掛程式實作可拖曳功能

以上是ztree實作權限橫向顯示功能實例分享的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn