需求:打开页面后已经生成一棵带有节点的树,需要实时更新该树每个节点的状态,根据状态,改变节点的ICON和FONT样式。说明:找了一下,基本上都是说加载时指定颜色的,加载时指定颜色的用法,在官方示例中就有说明:示例:显示自定义字体的树

示例:自定义图标 -- icon 属性

可以看到每个NODE都有一个FONT的属性,和NAME同等级。可以通过设置FONT来指定其文本样式。通过第二个示例可以看到,还有一个ICON属性。可以通过设置ICON属性来设置更改后的图标。应用:实时更新树状态ICON和FONT样式
$(document).ready(function(){

$.fn.zTree.init($("#treeDemo"), setting, 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){

var node = zTree.getNodeByParam("id", code, null); // 每个树都有编号,通过编号找节点

if(null != node){

node.font={'color':'red'};
// 设置文本样式,这里设置文本颜色

node.icon=baseImgPath+"monitor.png"; // 设置节点图标

zTree.updateNode(node);
// 更新该节点

}

}

}

setTimeout("updateTree()",1000);

}
}
$(document).ready(function(){

$.fn.zTree.init($("#treeDemo"), setting, 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){

var node = zTree.getNodeByParam("id", code, null); // 每个树都有编号,通过编号找节点

if(null != node){

node.font={'color':'red'};
// 设置文本样式,这里设置文本颜色

node.icon=baseImgPath+"monitor.png"; // 设置节点图标

zTree.updateNode(node);
// 更新该节点

}

}

}

setTimeout("updateTree()",1000);

}
} 备注:这里使用DWR进行异步交互,返回需要更新的列表编码。实际应用中可以根据实际情况,返回响应对象,并根据对象的属性判断到底更新为那种样式。这里不建议使用 setInterval,建议采用setTimeout在轮询一次以后再开始下次更新操作。以上就是本文的全部内容,希望对大家的学习有所帮助。