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>
上記の例では、ノードFirstName、LastName、およびEmployeeの情報にアクセスしています。
xmlDoc.getElementsByTagName( "FirstName")[0] .childNodes [0] .nodeValue; この行は、getElementByTagName()メソッドを使用して子ノードFirstNameの値にアクセスします。
xmlDoc.getElementsByTagName( "Employee")[0] .attributes [0] .nodeValue; この行は、ノードのEmployee getElementByTagName()メソッドの属性値にアクセスします。
ノードをトラバースする
これについては、「DOMトラバース」の章で例を挙げて説明しています。
ノードをナビゲートする
これについては、「DOMナビゲーション」の章で例を挙げて説明しています。