XMLDOM-アクセス

この章では、XMLドキュメントの情報単位と見なされるXMLDOMノードにアクセスする方法について学習します。XML DOMのノード構造により、開発者はツリー内を移動して特定の情報を探し、同時にその情報にアクセスできます。

ノードへのアクセス

以下は、ノードにアクセスするための3つの方法です-

  • を使用して getElementsByTagName () 方法

  • ノードツリーをループまたはトラバースする

  • ノード関係を使用して、ノードツリーをナビゲートする

getElementsByTagName()

この方法では、ノード名を指定することでノードの情報にアクセスできます。また、ノードリストとノードリストの長さの情報にアクセスすることもできます。

構文

getElementByTagName()メソッドの構文は次のとおりです。

node.getElementByTagName("tagname");

どこ、

  • node-はドキュメントノードです。

  • tagname-値を取得するノードの名前を保持します。

以下は、メソッドgetElementByTagNameの使用法を示す簡単なプログラムです。

<!DOCTYPE html>
<html>
   <body>
      <div>
         <b>FirstName:</b> <span id = "FirstName"></span><br>
         <b>LastName:</b> <span id = "LastName"></span><br>
         <b>Category:</b> <span id = "Employee"></span><br>
      </div>
      <script>
         if (window.XMLHttpRequest) {// code for IE7+, Firefox, Chrome, Opera, Safari
            xmlhttp = new XMLHttpRequest();
         } else {// code for IE6, IE5
            xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
         }
         xmlhttp.open("GET","/dom/node.xml",false);
         xmlhttp.send();
         xmlDoc = xmlhttp.responseXML;

         document.getElementById("FirstName").innerHTML = 
         xmlDoc.getElementsByTagName("FirstName")[0].childNodes[0].nodeValue;
         document.getElementById("LastName").innerHTML = 
         xmlDoc.getElementsByTagName("LastName")[0].childNodes[0].nodeValue;
         document.getElementById("Employee").innerHTML = 
         xmlDoc.getElementsByTagName("Employee")[0].attributes[0].nodeValue;
      </script>
   </body>
</html>
  • 上記の例では、ノードFirstNameLastName、およびEmployeeの情報にアクセスしています。

  • xmlDoc.getElementsByTagName( "FirstName")[0] .childNodes [0] .nodeValue; この行は、getElementByTagName()メソッドを使用して子ノードFirstNameの値にアクセスします。

  • xmlDoc.getElementsByTagName( "Employee")[0] .attributes [0] .nodeValue; この行は、ノードのEmployee getElementByTagName()メソッドの属性値にアクセスします。

ノードをトラバースする

これについては、「DOMトラバース」の章で例を挙げて説明しています。

ノードをナビゲートする

これについては、「DOMナビゲーション」の章で例を挙げて説明しています。