AJAX开发简略 (第二部分)

2019-09-14 07:33:37王旭

function countTotalElement(node) { //参数node是一个Node对象
	var total = 0;
	if(node.nodeType == 1) { //检查node是否为Element对象
		total++;			//如果是,计数器加1
		elementName = elementName + node.tagName + "rn"; //保存标记名
	}
	var childrens = node.childNodes;		//获取node的全部子节点
	for(var m=node.firstChild; m!=null;m=m.nextSibling) {
		total += countTotalElement(m); //在每个子节点上进行递归操作
	}
	return total;
}

  B、搜索文档中特定的元素
  在使用DOM的过程中,有时候需要定位到文档中的某个特定节点,或者具有特定类型的节点列表。这种情况下,可以调用Document对象的getElementsByTagName()和getElementById()方法来实现。

  document.getElementsByTagName()返回文档中具有指定标记名的全部Element节点数组(也是NodeList类型)。Element出现在数组中的顺序就是他们在文档中出现的顺序。传递给getElementsByTagName()的参数忽略大小写。比如,想定位到第一个<table>标记,可以这样写:document.getElementsByTagName(“table”)[0]。例外的,可以使用document.body定位到<body>标记,因为它是唯一的。

  getElementsByTagName()返回的数组取决于文档。一旦文档改变,返回结果也立即改变。相比,getElementById()则比较灵活,可以随时定位到目标,只是要实现给目标元素一个唯一的id属性值。这个我们在《AJAX开发简略》的“级联菜单”例子中已经使用过了。

  Element对象也支持getElementsByTagName()和getElementById()。不同的是,搜索领域只针对调用者的子节点。

  C、修改文档内容
  遍历整棵文档树、搜索特定的节点,我们最终目的之一是要修改文档内容。接下来的三个例子将使用Node的几个常用方法,来演示如何修改文档内容。

  例子3 -- sample4_1.htm:
  这个例子包含三个文本节点和一个按钮。点击按钮后,三个文本节点和按钮的顺序将被颠倒。程序使用了Node的appendChild()和removeChild()方法。

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>无标题文档</title>
<script language="javascript">
	function reverseNode(node) { // 颠倒节点node的顺序
		var kids = node.childNodes; //获取子节点列表
		var kidsNum = kids.length; //统计子节点总数
		for(var i=kidsNum-1;i>=0;i--) { //逆向遍历子节点列表
			var c = node.removeChild(kids[i]); //删除指定子节点,保存在c中
			node.appendChild(c); //将c放在新位置上
		}
	}
</script>
</head>
<body>
<p>第一行</p>
<p>第二行</p>
<p>第三行</p>
<p><input type="button" name="reverseGo" value="颠倒" 
onClick="reverseNode(document.body)"></p>
</body>
</html>