jQuery zTree如何改變指定節(jié)點文本樣式
需求:打開頁面后已經(jīng)生成一棵帶有節(jié)點的樹,需要實時更新該樹每個節(jié)點的狀態(tài),根據(jù)狀態(tài),改變節(jié)點的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>
示例:自定義圖標(biāo) -- icon 屬性
<SCRIPT type="text/javascript">
<!--
var setting = {
data: {
simpleData: {
enable: true
}
}
};
var zNodes =[
{ id:1, pId:0, name:"展開、折疊 自定義圖標(biāo)不同", open:true, iconOpen:"../../../css/zTreeStyle/img/diy/1_open.png", iconClose:"../../../css/zTreeStyle/img/diy/1_close.png"},
{ id:11, pId:1, name:"葉子節(jié)點1", icon:"../../../css/zTreeStyle/img/diy/2.png"},
{ id:12, pId:1, name:"葉子節(jié)點2", icon:"../../../css/zTreeStyle/img/diy/3.png"},
{ id:13, pId:1, name:"葉子節(jié)點3", icon:"../../../css/zTreeStyle/img/diy/5.png"},
{ id:2, pId:0, name:"展開、折疊 自定義圖標(biāo)相同", open:true, icon:"../../../css/zTreeStyle/img/diy/4.png"},
{ id:21, pId:2, name:"葉子節(jié)點1", icon:"../../../css/zTreeStyle/img/diy/6.png"},
{ id:22, pId:2, name:"葉子節(jié)點2", icon:"../../../css/zTreeStyle/img/diy/7.png"},
{ id:23, pId:2, name:"葉子節(jié)點3", <span style="color: #ff0000;">icon:"../../../css/zTreeStyle/img/diy/8.png"</span>},
{ id:3, pId:0, name:"不使用自定義圖標(biāo)", open:true },
{ id:31, pId:3, name:"葉子節(jié)點1"},
{ id:32, pId:3, name:"葉子節(jié)點2"},
{ id:33, pId:3, name:"葉子節(jié)點3"}
];
$(document).ready(function(){
$.fn.zTree.init($("#treeDemo"), setting, zNodes);
});
//-->
</SCRIPT>
可以看到每個NODE都有一個FONT的屬性,和NAME同等級??梢酝ㄟ^設(shè)置FONT來指定其文本樣式。
通過第二個示例可以看到,還有一個ICON屬性??梢酝ㄟ^設(shè)置ICON屬性來設(shè)置更改后的圖標(biāo)。
應(yīng)用:實時更新樹狀態(tài)ICON和FONT樣式
$(document).ready(function(){
$.fn.zTree.init($("#treeDemo"), setting, zNodes);
zTree = $.fn.zTree.getZTreeObj("treeDemo");
rMenu = $("#rMenu");
setTimeout("updateDev()",1000); // 在初始化樹之后,開始更新狀態(tài),就別用setInterval了
});
var baseImgPath = "<%=basePath%>img/"; // basePath是通過JSP獲得的系統(tǒng)根路徑,不用相對路徑
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> // 每個樹都有編號,通過編號找節(jié)點
if(null != node){
<span style="color: #ff0000;">node.font={'color':'red'};</span> // 設(shè)置文本樣式,這里設(shè)置文本顏色
<span style="color: #ff0000;">node.icon=baseImgPath+"monitor.png";</span> // 設(shè)置節(jié)點圖標(biāo)
zTree.updateNode(node); // 更新該節(jié)點
}
}
}
setTimeout("updateTree()",1000);
}
}
備注:
這里使用DWR進行異步交互,返回需要更新的列表編碼。實際應(yīng)用中可以根據(jù)實際情況,返回響應(yīng)對象,并根據(jù)對象的屬性判斷到底更新為那種樣式。
這里不建議使用 setInterval,建議采用setTimeout在輪詢一次以后再開始下次更新操作。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
web前端開發(fā)JQuery常用實例代碼片段(50個)
本文給大家展示50個jquery代碼片段,這些代碼能夠給你的javascript項目提供幫助,需要的朋友快來學(xué)習(xí)一下吧2015-08-08
JQuery實現(xiàn)網(wǎng)頁右側(cè)隨動廣告特效
本文給大家分享的是2則使用jquery實現(xiàn)網(wǎng)頁右側(cè)隨動廣告特效的代碼,非常的簡單實用,有需要的小伙伴可以參考下。2016-01-01
JQuery zClip插件實現(xiàn)復(fù)制頁面內(nèi)容到剪貼板
這篇文章主要介紹了JQuery zClip插件實現(xiàn)復(fù)制到剪貼板功能,并且兼容所有瀏覽器,大家可以學(xué)習(xí)借鑒此文章。2015-11-11
jquery.autocomplete修改實現(xiàn)鍵盤上下鍵自動填充示例
根據(jù)需求要實現(xiàn)通過鍵盤上下移動,獲得聯(lián)想菜單中的值,如同google baidu的查詢功能,下面的代碼是自己手寫的,喜歡的朋友可以嘗試操作下2013-11-11
jQuery插件datalist實現(xiàn)很好看的input下拉列表
本文給大家分享的是使用jQuery實現(xiàn)的房HTML5中的一個好看的input框很好看的下拉列表--datalist,兼容性非常不錯,這里推薦給大家,有需要的小伙伴可以參考下。2015-07-07

