zTree 改变指定节点文本样式
程序员文章站
2022-04-15 16:37:17
...
需求:打开页面后已经生成一棵带有节点的树,需要实时更新该树每个节点的状态,根据状态,改变节点的ICON和FONT样式。
说明:找了一下,基本上都是说加载时指定颜色的,加载时指定颜色的用法,在官方示例中就有说明:
示例:显示自定义字体的树
<SCRIPT type="text/javascript">
<!--
var setting = {
view: {
fontCss: getFont,
nameIsHTML: true
}
};
var zNodes =[
{ name:"粗体字", font:{'font-weight':'bold'} },
{ 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, pId:1, name:"叶子节点2", icon:"../../../css/zTreeStyle/img/diy/3.png"},
{ id:13, pId:1, name:"叶子节点3", icon:"../../../css/zTreeStyle/img/diy/5.png"},
{ id:2, pId:0, name:"展开、折叠 自定义图标相同", open:true, icon:"../../../css/zTreeStyle/img/diy/4.png"},
{ id:21, pId:2, name:"叶子节点1", icon:"../../../css/zTreeStyle/img/diy/6.png"},
{ id:22, pId:2, name:"叶子节点2", icon:"../../../css/zTreeStyle/img/diy/7.png"},
{ id:23, pId:2, name:"叶子节点3", icon:"../../../css/zTreeStyle/img/diy/8.png"},
{ id:3, pId:0, name:"不使用自定义图标", open:true },
{ id:31, pId:3, name:"叶子节点1"},
{ id:32, pId:3, name:"叶子节点2"},
{ id:33, pId:3, name:"叶子节点3"}
];
$(document).ready(function(){
$.fn.zTree.init($("#treeDemo"), setting, zNodes);
});
//-->
</SCRIPT>
可以看到每个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); } }
备注:
这里使用DWR进行异步交互,返回需要更新的列表编码。实际应用中可以根据实际情况,返回响应对象,并根据对象的属性判断到底更新为那种样式。
这里不建议使用 setInterval,建议采用setTimeout在轮询一次以后再开始下次更新操作。
请您到ITEYE网站看 java小强 原创,谢谢!
http://cuisuqiang.iteye.com/ !
自建博客地址:http://www.javacui.com/ ,内容与ITEYE同步!
上一篇: SQLServer之创建分布式事务
推荐阅读
-
HTML样式中移动鼠标到指定位置改变光标形状
-
文本框(input)获取焦点(onfocus)时样式改变的实现方法
-
Vue列表如何实现滚动到指定位置样式改变效果
-
动态改变ASP.net页面标题和动态指定页面样式表的方法
-
第三方文本框 在div中显示预览,让指定节点不受外部css影响_html/css_WEB-ITnose
-
文本框(input)获取焦点(onfocus)时样式改变的示例代码_javascript技巧
-
文本框(input)获取焦点(onfocus)时样式改变的示例代码_javascript技巧
-
第三方文本框 在div中显示预览,让指定节点不受外部css影响_html/css_WEB-ITnose
-
css设置具有指定type属性值的input文本框的样式_html/css_WEB-ITnose
-
elementUI之通过指定 Table 组件的 row-class-name 属性来为 Table 中的某一行添加 class改变该行的颜色等样式。