ホームページ  >  記事  >  ウェブフロントエンド  >  HTMLページノードを取得するjsメソッド(再帰的メソッド)

HTMLページノードを取得するjsメソッド(再帰的メソッド)

高洛峰
高洛峰オリジナル
2017-02-08 15:29:441081ブラウズ

長い間再帰呼び出しを行っていません。読み終わったら、突然目が覚めました!

コードは次のとおりです:

<!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>

実際、Baidu スパイダー クローラーと同じ効果は再帰呼び出しでも実現できます。この方法を使ってサイトマップ ジェネレーターを作成できるかもしれません。試してみる価値はあります。

HTML ページのノードを (再帰的に) 取得する方法に関するその他の JS 関連記事については、PHP 中国語 Web サイトに注目してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。