js获取html页面节点方法(递归方式)

  很久没有操作过递归调用了。看完之后,蓦然惊醒啊!

  

复制代码 代码如下:

  <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

  <html xmlns="http://www.w3.org/1999/xhtml">

  <head>

  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

  <title>统计Element节点</title>

  <script language="javascript">

  var  elementName="";

  function countTotalElement(node)

  {

  ///Attribute  nodeType值为2,表示节点属性

  ///Comment    nodeType值为8,表示注释文本

  ///Document   nodeType值为9,表示Document

  ///DocumentFragment   nodeType值为11,表示Document片段

  ///Element            nodeType值为1,表示元素节点

  ///Text               nodeType值为3,表示文本节点

  var total=0;

  if(node.nodeType==1) //1代表节点的类型为Element

  {

  total++;

  elementName=elementName+node.tagName+"\r\n";

  }

  var childrens=node.childNodes;

  for(var i=0;i<childrens.length;i++)

  {

  total+=countTotalElement(childrens[i]);

  }

  return total;

  }

  </script>

  </head>

  <body>

  <h1>测试</h1>

  <table width="100" border="2" cellpadding="0" cellspacing="0">

  <tr><td>

  <form name="form1" action="" method="post">

  <input type="text" name="ipput1" value="测试"><br />

  <input type="password" name="password" value="">

  </form>

  </td></tr>

  </table>

  <a href="javascript:void(0)" onClick="alert('标记总数'+countTotalElement(document)+'\r\n 全部标记如下:\r\n'+elementName);">开始测试</a>

  </body>

  </html>

  其实,通过递归调用也可以实现 想百度蜘蛛爬虫一样的效果!这个值得一试,或许可以通过这个方法,写一个sitemap生成器!