亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

ztree實(shí)現(xiàn)權(quán)限橫向顯示功能

 更新時(shí)間:2017年05月20日 13:29:26   作者:Tengri  
最近在做權(quán)限功能的時(shí)候,采用的ztree實(shí)現(xiàn)的,但是產(chǎn)品要求最后一層的權(quán)限節(jié)點(diǎn)要橫向顯示。下面小編把基于ztree實(shí)現(xiàn)權(quán)限橫向顯示功能的實(shí)現(xiàn)思路分享給大家,供大家參考

 最近在做權(quán)限功能的時(shí)候,采用的ztree實(shí)現(xiàn)的,但是產(chǎn)品要求最后一層的權(quán)限節(jié)點(diǎn)要橫向顯示。開始在網(wǎng)上找的解決方案是用css樣式把最后一層的display設(shè)置為inline。在我本地電腦上看了下。效果不錯。

但是,后來測試在用十年前的筆記本測這個(gè)功能的時(shí)候,發(fā)現(xiàn)特別的卡,導(dǎo)致瀏覽器都崩潰了。所以,性能優(yōu)化開始了。

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

2、設(shè)置showIcon和showLine為false,發(fā)現(xiàn)速度有一丟丟的提升,但是產(chǎn)品還是不滿意。

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

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

1、數(shù)據(jù)結(jié)構(gòu),要求有一個(gè)isLeaf節(jié)點(diǎn),標(biāo)記是否是子節(jié)點(diǎn)。

var zNodes =[
      { id:1, pId:0, name:"父節(jié)點(diǎn) 1", open:true,isLeaf:false},
      { id:11, pId:1, name:"葉子節(jié)點(diǎn) 1-1",isLeaf:true},
      { id:12, pId:1, name:"葉子節(jié)點(diǎn) 1-2",open:true,isLeaf:false},
      { id:120, pId:12, name:"葉子節(jié)點(diǎn) 1-2-0",isLeaf:true},
      { id:121, pId:12, name:"葉子節(jié)點(diǎn) 1-2-1",isLeaf:true},
      { id:13, pId:1, name:"葉子節(jié)點(diǎn) 1-3",isLeaf:true},
      { id:2, pId:0, name:"父節(jié)點(diǎn) 2", open:true,isLeaf:false},
      { id:21, pId:2, name:"葉子節(jié)點(diǎn) 2-1",isLeaf:true},
      { id:22, pId:2, name:"葉子節(jié)點(diǎn) 2-2",isLeaf:true},
      { id:23, pId:2, name:"葉子節(jié)點(diǎn) 2-3",isLeaf:true},
      { id:3, pId:0, name:"父節(jié)點(diǎn) 3", open:true,isLeaf:false},
      { id:31, pId:3, name:"葉子節(jié)點(diǎn) 3-1",isLeaf:true},
      { id:32, pId:3, name:"葉子節(jié)點(diǎn) 3-2",isLeaf:true},
      { id:33, pId:3, name:"葉子節(jié)點(diǎn) 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、自己寫的幾個(gè)級聯(lián)操作的方法

function checkedHandler(checkbox){
      var $checkbox = $(checkbox),
        treeNode = $checkbox.data("treeNode"),
        state = checkbox.checked;
        if(treeNode.isLeaf){ //子節(jié)點(diǎn)
          if(state){ //子節(jié)點(diǎn)選中,父節(jié)點(diǎn)要跟著選中,子節(jié)點(diǎn)取消選擇,父節(jié)點(diǎn)不用級聯(lián)
            setParentNodeChecked(checkbox);
          }
        }else{ //父節(jié)點(diǎn)
          if(state){ //選中,級聯(lián)子節(jié)點(diǎn),級聯(lián)父節(jié)點(diǎn)
            setParentNodeChecked(checkbox);
            setChildNodeChecked(checkbox);
          }else{
            setChildNodeChecked(checkbox);
          }
        }
    }
    /**設(shè)置父節(jié)點(diǎn)選中 */
    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);
    }
    /**設(shè)置子節(jié)點(diǎn)選中 */
    function setChildNodeChecked(checkbox){
      $(checkbox).closest("li").find(".checkboxBtn").each(function(){
        this.checked = checkbox.checked;
      });
    }

4、css中,設(shè)置:

.ztree li.isLeaf{
  display:inline;
 }

以上所述是小編給大家介紹的ztree實(shí)現(xiàn)權(quán)限橫向顯示功能,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時(shí)回復(fù)大家的,在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

最新評論