|  | 
 
| 
DOM将一个HTML文档解析为树状结构,并提供相应的方案来遍历整个HTML文档树。两个遍历树的例子。 这个例子使用了childNodes[]和递归方式来遍历整个文档,统计文档中出现的Element元素总数,并把Element标记名全部打印出来。
 sample4_12.htm
 <html>
 <head>
 <meta http-equiv="Content-Type" content="text/html; charset=gb2312">
 <title>Ch04--统计Element节点总数</title>
 <script language="javascript">
 var elementName = ""; //全局变量,保存Element标记名,使用完毕要清空
 
 function countTotalElement(node) { //参数node是一个Node对象
 var total = 0;
 if(node.nodeType == 1) { //检查node是否为Element对象
 total++;          //如果是,计数器加1
 elementName = elementName + node.tagName + "\r\n"; //保存标记名
 }
 var childrens = node.childNodes;       //获取node的全部子节点
 for(var i=0;i<childrens.length;i++) {
 total += countTotalElement(childrens); //在每个子节点上进行递归操作
 }
 return total;
 }
 </script>
 </head>
 <body>
 <table width="100" border="1" cellpadding="0" cellspacing="0">
 <tr><td>
 <form name="form1" action="" method="post">
 <input type="text" name="input1" value=""><br>
 <input type="password" name="password1" value="">
 </form>
 </td></tr>
 </table>
 <a href="javascript:void(0)" onClick="alert('标记总数:' + countTotalElement (document) + '\r\n全部标记如下:\r\n' + elementName); elementName='';">开始统计</a>
 </body>
 </html>
 注意事项:
 1、在使用DOM时,必须等文档被装载完毕再执行遍历等行为操作文档。
 2、<tbody>标记并没有被使用,但是在统计Element节点总数的时候,<tbody>还是被统计进来了。因为如果没有显式地指定<tr>所属的<thead>、<tbody>或者<tfoot>,则HTML将<tr>标记置入一个默认的<tbody>标签内加以解析。另外,<thead>、<tbody>和<tfoot>标记在一个表格标记内部只能分别有一个。
 
 则使用firstChile、lastChild、nextSibling、previousSibling等树状遍历整个文档树。
 sample4_13.htm
 <html>
 <head>
 <meta http-equiv="Content-Type" content="text/html; charset=gb2312">
 <title>Ch04--统计Element节点总数</title>
 <script language="javascript">
 var elementName = ""; //全局变量,保存Element标记名,使用完毕要清空
 function countTotalElement(node) { //参数node是一个Node对象
 var total = 0;
 if(node.nodeType == 1) { //检查node是否为Element对象
 total++;          //如果是,计数器加1
 elementName = elementName + node.tagName + "\r\n"; //保存标记名
 }
 for(var m=node.firstChild; m!=null;m=m.nextSibling) {
 total += countTotalElement(m); //在每个子节点上进行递归操作
 }
 return total;
 }
 </script>
 </head>
 
 <body>
 <table width="100" border="1" cellpadding="0" cellspacing="0">
 <tr><td>
 <form name="form1" action="" method="post">
 <input type="text" name="input1" value=""><br>
 <input type="password" name="password1" value="">
 </form>
 </td></tr>
 </table>
 <a href="javascript:void(0)" onClick="alert('标记总数:' + countTotalElement (document) + '\r\n全部标记如下:\r\n' + elementName); elementName='';">开始统计</a>
 </body>
 </html>
 | 
 |