>웹 프론트엔드 >JS 튜토리얼 >html 페이지 노드를 가져오는 js 메소드(재귀적 메소드)

html 페이지 노드를 가져오는 js 메소드(재귀적 메소드)

高洛峰
高洛峰원래의
2017-02-08 15:29:441088검색

오랫동안 재귀 호출을 하지 않았습니다. 읽고 나서 갑자기 일어났습니다!

코드는 다음과 같습니다.

<!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(&#39;标记总数&#39;+countTotalElement(document)+&#39;\r\n 全部标记如下:\r\n&#39;+elementName);">开始测试</a>
</body>
</html>

실제로 재귀 호출을 통해서도 바이두 스파이더 크롤러와 동일한 효과를 얻을 수 있습니다! 이것은 시도해 볼 가치가 있습니다. 아마도 이 방법을 사용하여 사이트맵 생성기를 작성할 수 있습니다!

html 페이지 노드를 (재귀적으로) 얻는 방법에 대한 더 많은 js 관련 기사를 보려면 PHP 중국어 웹사이트에 주목하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.