XMLDOM-クローンノード
この章では、XMLDOMオブジェクトでのノードの複製操作について説明します。ノードの複製操作は、指定されたノードの複製コピーを作成するために使用されます。この操作にはcloneNode()が使用されます。
cloneNode()
このメソッドは、このノードの複製を返します。つまり、ノードの汎用コピーコンストラクターとして機能します。重複ノードには親がなく(parentNodeはnull)、ユーザーデータもありません。
構文
cloneNodeを()メソッドは、次の構文を持っています-
Node cloneNode(boolean deep)
deep − trueの場合、指定されたノードの下にサブツリーを再帰的に複製します。falseの場合、ノード自体(および要素の場合はその属性)のみを複製します。
このメソッドは重複ノードを返します。
例
次の例(clonenode_example.htm)は、XMLドキュメント(node.xml)をXML DOMオブジェクトに解析し、最初のEmployee要素のディープコピーを作成します。
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
} else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
x = xmlDoc.getElementsByTagName('Employee')[0];
clone_node = x.cloneNode(true);
xmlDoc.documentElement.appendChild(clone_node);
firstname = xmlDoc.getElementsByTagName("FirstName");
lastname = xmlDoc.getElementsByTagName("LastName");
contact = xmlDoc.getElementsByTagName("ContactNo");
email = xmlDoc.getElementsByTagName("Email");
for (i = 0;i < firstname.length;i++) {
document.write(firstname[i].childNodes[0].nodeValue+'
'+lastname[i].childNodes[0].nodeValue+',
'+contact[i].childNodes[0].nodeValue+', '+email[i].childNodes[0].nodeValue);
document.write("<br>");
}
</script>
</body>
</html>
上記の例でわかるように、cloneNode()パラメータをtrueに設定しました。したがって、Employee要素の下の各子要素がコピーまたは複製されます。
実行
このファイルをclonenode_example.htmとしてサーバーパスに保存します(このファイルとnode.xmlはサーバー内の同じパスにある必要があります)。以下のような出力が得られます−
Tanmay Patil, 1234567890, [email protected]
Taniya Mishra, 1234667898, [email protected]
Tanisha Sharma, 1234562350, [email protected]
Tanmay Patil, 1234567890, [email protected]
最初のEmployee要素が完全に複製されていることがわかります。