当前位置:首页 > 开发 > Web前端 > 前端 > 正文

zTree 改变指定节点文本样式

发表于: 2014-03-06   作者:cuisuqiang   来源:转载   浏览次数:
摘要: 需求:打开页面后已经生成一棵带有节点的树,需要实时更新该树每个节点的状态,根据状态,改变节点的ICON和FONT样式。 说明:找了一下,基本上都是说加载时指定颜色的,加载时指定颜色的用法,在官方示例中就有说明:   示例:显示自定义字体的树  <SCRIPT type="text/javascript"> <!-- var

需求:打开页面后已经生成一棵带有节点的树,需要实时更新该树每个节点的状态,根据状态,改变节点的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同步!

zTree 改变指定节点文本样式

  • 0

    开心

    开心

  • 0

    板砖

    板砖

  • 0

    感动

    感动

  • 0

    有用

    有用

  • 0

    疑问

    疑问

  • 0

    难过

    难过

  • 0

    无聊

    无聊

  • 0

    震惊

    震惊

编辑推荐
ztreedemo.jsp: <%@ page language="java" import="java.util.*" pageEncoding="utf-8"%> <
照样先弄个图上来: 很多时候,我们都希望网站上面的按钮可以和网站的颜色相配 其实很简单,只要在
前几天我的教程里给出了一个作业,改变 ProgressBar 样式颜色。在这里分享一下源码。改变ProgressBa
语法: Object.style.property=new style; 注意:Object是获取的元素对象,如通过document.getElement
<mx:Tree x="9" y="8" defaultLeafIcon="@Embed(source='img/Tree_defaultLeafIcon.png')" folde
1、文本缩进 text-indent JavaScript 语法:object.style.textIndent="50px" 示例: 如段落的第一行
<html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-T
新加了个文件上传的功能,领导说页面不好看,让我修改下页面,我对CSS又不太熟悉,费了好大一会功夫
当今多数浏览器支持一下指针样式(将鼠标移动到样式名称上以观察指针样式改变为那个样式): auto mo
js代码: var curMenu = null, zTree_Menu = null; var setting = { async:{ autoParam:["menuid"],
版权所有 IT知识库 CopyRight © 2009-2015 IT知识库 IT610.com , All Rights Reserved. 京ICP备09083238号