很久沒有操作過遞迴呼叫了。看完之後,驀然驚醒啊!
複製代碼代碼如下:
<!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 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生成器!