XMLDOM-ナビゲーション
これまで、DOM構造、XML DOMオブジェクトをロードして解析する方法、およびDOMオブジェクトをトラバースする方法について学習しました。ここでは、DOMオブジェクト内のノード間を移動する方法を説明します。XML DOMは、ノードをナビゲートするのに役立つノードのさまざまなプロパティで構成されています。
- parentNode
- childNodes
- firstChild
- lastChild
- nextSibling
- previousSibling
以下は、他のノードとの関係を示すノードツリーの図です。
DOM-親ノード
このプロパティは、親ノードをノードオブジェクトとして指定します。
例
次の例(navigate_example.htm)は、XMLドキュメント(node.xml)をXMLDOMオブジェクトに解析します。次に、DOMオブジェクトは子ノードを介して親ノードにナビゲートされます-
<!DOCTYPE html>
<html>
<body>
<script>
if (window.XMLHttpRequest) {
xmlhttp = new XMLHttpRequest();
} else {
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.open("GET","/dom/node.xml",false);
xmlhttp.send();
xmlDoc = xmlhttp.responseXML;
var y = xmlDoc.getElementsByTagName("Employee")[0];
document.write(y.parentNode.nodeName);
</script>
</body>
</html>
上記の例でわかるように、子ノードEmployeeはその親ノードに移動します。
実行
このファイルをnavigate_example.htmlとしてサーバーパスに保存します(このファイルとnode.xmlはサーバー内の同じパスにある必要があります)。出力では、Employeeの親ノード、つまりCompanyを取得します。
第一子
このプロパティはNode型であり、NodeListに存在する最初の子名を表します。
例
次の例(first_node_example.htm)は、XMLドキュメント(node.xml)をXML DOMオブジェクトに解析してから、DOMオブジェクトに存在する最初の子ノードに移動します。
<!DOCTYPE html>
<html>
<body>
<script>
if (window.XMLHttpRequest) {
xmlhttp = new XMLHttpRequest();
} else {
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.open("GET","/dom/node.xml",false);
xmlhttp.send();
xmlDoc = xmlhttp.responseXML;
function get_firstChild(p) {
a = p.firstChild;
while (a.nodeType != 1) {
a = a.nextSibling;
}
return a;
}
var firstchild = get_firstChild(xmlDoc.getElementsByTagName("Employee")[0]);
document.write(firstchild.nodeName);
</script>
</body>
</html>
関数get_firstChild(p)は、空のノードを回避するために使用されます。ノードリストからfirstChild要素を取得するのに役立ちます。
x = get_firstChild(xmlDoc.getElementsByTagName("Employee")[0])タグ名Employeeの最初の子ノードをフェッチします。
実行
このファイルをfirst_node_example.htmとしてサーバーパスに保存します(このファイルとnode.xmlはサーバー内の同じパスにある必要があります)。出力では、我々は最初の子ノードを取得従業員 つまり姓を。
最後の子
このプロパティはNode型であり、NodeListに存在する最後の子名を表します。
例
次の例(last_node_example.htm)は、XMLドキュメント(node.xml)をXML DOMオブジェクトに解析してから、xmlDOMオブジェクトに存在する最後の子ノードに移動します。
<!DOCTYPE html>
<body>
<script>
if (window.XMLHttpRequest) {
xmlhttp = new XMLHttpRequest();
} else {
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.open("GET","/dom/node.xml",false);
xmlhttp.send();
xmlDoc = xmlhttp.responseXML;
function get_lastChild(p) {
a = p.lastChild;
while (a.nodeType != 1){
a = a.previousSibling;
}
return a;
}
var lastchild = get_lastChild(xmlDoc.getElementsByTagName("Employee")[0]);
document.write(lastchild.nodeName);
</script>
</body>
</html>
実行
このファイルをサーバーパスにlast_node_example.htmとして保存します(このファイルとnode.xmlはサーバー内の同じパスにある必要があります)。出力では、Employeeの最後の子ノード(Email)を取得します。
次の兄弟
このプロパティはNode型であり、次の子、つまりNodeListに存在する指定された子要素の次の兄弟を表します。
例
次の例(nextSibling_example.htm)は、XMLドキュメント(node.xml)をXML DOMオブジェクトに解析します。このオブジェクトは、xmlドキュメントに存在する次のノードにすぐに移動します。
<!DOCTYPE html>
<body>
<script>
if (window.XMLHttpRequest) {
xmlhttp = new XMLHttpRequest();
}
else {
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.open("GET","/dom/node.xml",false);
xmlhttp.send();
xmlDoc = xmlhttp.responseXML;
function get_nextSibling(p) {
a = p.nextSibling;
while (a.nodeType != 1) {
a = a.nextSibling;
}
return a;
}
var nextsibling = get_nextSibling(xmlDoc.getElementsByTagName("FirstName")[0]);
document.write(nextsibling.nodeName);
</script>
</body>
</html>
実行
このファイルをnextSibling_example.htmとしてサーバーパスに保存します(このファイルとnode.xmlはサーバー内の同じパスにある必要があります)。出力では、FirstNameの次の兄弟ノード、つまりLastNameを取得します。
前の兄弟
このプロパティはNode型であり、前の子、つまりNodeListに存在する指定された子要素の前の兄弟を表します。
例
次の例(previoussibling_example.htm)は、XMLドキュメント(node.xml)をXML DOMオブジェクトに解析してから、xmlドキュメントに存在する最後の子ノードのbeforeノードをナビゲートします。
<!DOCTYPE html>
<body>
<script>
if (window.XMLHttpRequest)
{
xmlhttp = new XMLHttpRequest();
} else {
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.open("GET","/dom/node.xml",false);
xmlhttp.send();
xmlDoc = xmlhttp.responseXML;
function get_previousSibling(p) {
a = p.previousSibling;
while (a.nodeType != 1) {
a = a.previousSibling;
}
return a;
}
prevsibling = get_previousSibling(xmlDoc.getElementsByTagName("Email")[0]);
document.write(prevsibling.nodeName);
</script>
</body>
</html>
実行
このファイルをprevioussibling_example.htmとしてサーバーパスに保存します(このファイルとnode.xmlはサーバー内の同じパスにある必要があります)。出力では、Eメールの前の兄弟ノード、つまりContactNoを取得します。