手机端小强原创文章,java小强个人博客站点
当前位置: 首页 >> JS >> zTree 改变指定节点文本样式

zTree 改变指定节点文本样式

92750 JS | 2014-8-6

需求:打开页面后已经生成一棵带有节点的树,需要实时更新该树每个节点的状态,根据状态,改变节点的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, 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", <SPAN style="COLOR: #ff0000">icon:"../../../css/zTreeStyle/img/diy/8.png"</SPAN>},
  { 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){
    <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在轮询一次以后再开始下次更新操作。

推荐您阅读更多有关于“ js 样式 ztree 节点 状态 ”的文章

上一篇:JS操作DOM 使用表格动态展示数据 下一篇:Oracle查询表的外键

猜你喜欢

发表评论:

个人资料
blogger

java小强
没有思考,人生的路会越走越难!

搜索
分类
最新微语
  • 车也学了,年也过了,生日也过了,村里的会也赶了,这次,是真的,年过去了。不过我没回京,也没有在家找工作,我在等什么吗?反正现在正合了我这个懒人的要求,不过,我歇不住,思考下人生。

    2018-03-20 00:11

  • 8月1日,我已离开奋斗多年的北京。不知道是暂时的离开,还是永久的离别,反正已经离职在家,告别每日上班,每天苦累的煎熬,过一段属于自己的生活。以前是专职工作,现在专职生活。

    2017-08-18 12:47

  • 又弄完一个项目,累成狗,但是感觉又进步不少,除了很多坑已经踩过,做起来也是轻车熟路。同时也认识到,程序不在于你多牛逼,而是在乎你的细节把控度,而细节的关注,是一个优秀程序员必须要注意的。另外,要相信自己,勇敢向前,没人生下来就是成功的,而且,成功的路,比成功本身更重要。

    2017-06-30 09:46

  • 今日北京再次沙尘暴来袭,吃了几年细粮,终于能来口粗粮了,不过大早上看见这场景,还是吓我一跳,不过随后就平静了,毕竟是老朋友了。进公司又发现一股烤糊的味道,真是祸不单行啊,例外都是污染。发了两个口罩,开启保护模式。

    2017-05-04 10:16

  • 今天同学问我,最近还在写代码吗?我想了想,这个问题怎么回答呢,我好像确实很长时间,虽然写了一些,但是主要内容已经不是写代码了。然后再想想,自己也7年多了,这么多年了,我收获了什么,我的目标到底是什么。眼看就奔三了,人生啊,开启感叹模式。

    2017-03-30 22:52

  • 更多»

最新文章
热门文章
随机文章