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要素が完全に複製されていることがわかります。