1. 程式人生 > 程式設計 >jQuery zTree如何改變指定節點文字樣式

jQuery zTree如何改變指定節點文字樣式

需求:開啟頁面後已經生成一棵帶有節點的樹,需要實時更新該樹每個節點的狀態,根據狀態,改變節點的ICON和FONT樣式。

說明:找了一下,基本上都是說載入時指定顏色的,載入時指定顏色的用法,在官方示例中就有說明:

示例:顯示自定義字型的樹

<SCRIPT type="text/javascript"> 
  <!-- 
  var setting = { 
    view: { 
      fontCss: getFont,nameIsHTML: true 
    } 
  }; 
  var zNodes =[ 
    { name:"粗體字",<span style="color: #ff0000;">font:{'font-weight':'bold'}</span> },{ name:"斜體字",font:{'font-style':'italic'}},{ name:"有背景的字",font:{'background-color':'black','color':'white'}},{ name:"紅色字",font:{'color':'red'}},{ name:"藍色字",font:{'color':'blue'}},{ name:"<span style='color:blue;margin-right:0px;'>view</span>.<span style='color:red;margin-right:0px;'>nameIsHTML</span>"},{ name:"zTree 預設樣式"} 
  ]; 
  function getFont(treeId,node) { 
    return node.font ? node.font : {}; 
  } 
  $(document).ready(function(){ 
    $.fn.zTree.init($("#treeDemo"),setting,zNodes); 
  }); 
  //--> 
</SCRIPT> 

示例:自定義圖示 -- icon 屬性

<SCRIPT type="text/javascript"> 
  <!-- 
  var setting = { 
    data: { 
      simpleData: { 
        enable: true 
      } 
    } 
  }; 
  var zNodes =[ 
    { id:1,pId:0,name:"展開、摺疊 自定義圖示不同",open:true,iconOpen:"../../../css/zTreeStyle/img/diy/1_open.png",iconClose:"../../../css/zTreeStyle/img/diy/1_close.png"},{ id:11,pId:1,name:"葉子節點1",icon:"../../../css/zTreeStyle/img/diy/2.png"},{ id:12,name:"葉子節點2",icon:"../../../css/zTreeStyle/img/diy/3.png"},{ id:13,name:"葉子節點3",icon:"../../../css/zTreeStyle/img/diy/5.png"},{ id:2,name:"展開、摺疊 自定義圖示相同",icon:"../../../css/zTreeStyle/img/diy/4.png"},{ id:21,pId:2,icon:"../../../css/zTreeStyle/img/diy/6.png"},{ id:22,icon:"../../../css/zTreeStyle/img/diy/7.png"},{ id:23,<span style="color: #ff0000;">icon:"../../../css/zTreeStyle/img/diy/8.png"</span>},{ id:3,name:"不使用自定義圖示",open:true },{ id:31,pId:3,name:"葉子節點1"},{ id:32,name:"葉子節點2"},{ id:33,name:"葉子節點3"} 
  ]; 
  $(document).ready(function(){ 
    $.fn.zTree.init($("#treeDemo"),zNodes); 
  }); 
  //--> 
</SCRIPT> 

可以看到每個NODE都有一個FONT的屬性,和NAME同等級。可以通過設定FONT來指定其文字樣式。

通過第二個示例可以看到,還有一個ICON屬性。可以通過設定ICON屬性來設定更改後的圖示。

應用:實時更新樹狀態ICON和FONT樣式

$(document).ready(function(){ 
  $.fn.zTree.init($("#treeDemo"),zNodes); 
  zTree = $.fn.zTree.getZTreeObj("treeDemo"); 
  rMenu = $("#rMenu"); 
  setTimeout("updateDev()",1000);  // 在初始化樹之後,開始更新狀態,就別用setInterval了 
}); 
var baseImgPath = "<%=basePath%>img/";   // basePath是通過JSP獲得的系統根路徑,不用相對路徑 
function updateTree(){ 
  toDwr.getAllCode(function back(values){ 
    if(null != values && ""!=values){ 
      for(var code in values){ 
        <span style="color: #ff0000;">var node = zTree.getNodeByParam("id",code,null);</span> // 每個樹都有編號,通過編號找節點 
        if(null != node){ 
          <span style="color: #ff0000;">node.font={'color':'red'};</span>      // 設定文字樣式,這裡設定文字顏色 
          <span style="color: #ff0000;">node.icon=baseImgPath+"monitor.png";</span> // 設定節點圖示 
          zTree.updateNode(node);       // 更新該節點 
        } 
      } 
    } 
    setTimeout("updateTree()",1000); 
  } 
} 

備註:

這裡使用DWR進行非同步互動,返回需要更新的列表編碼。實際應用中可以根據實際情況,返回響應物件,並根據物件的屬性判斷到底更新為那種樣式。

這裡不建議使用 setInterval,建議採用setTimeout在輪詢一次以後再開始下次更新操作。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。