返回首页
当前位置: 主页 > 编程语言 > XML教程 >

XML DOM-克隆节点

时间:2020-07-09 15:29来源:电脑教程学习网 www.etwiki.cn 编辑:小山哥

在本章中,我们将讨论对XML DOM对象的“ 克隆节点”操作。克隆节点操作用于创建指定节点的副本。cloneNode()用于此操作。

cloneNode()

此方法返回此节点的副本,即用作节点的通用副本构造函数。复制节点没有父节点(parentNode为null),也没有用户数据。

句法

cloneNode()方法具有下面的语法-

Node cloneNode(boolean deep)
  • deep-如果为true,则递归地将子树克隆到指定节点下;如果为false,则仅克隆节点本身(及其元素(如果为Element))。

  • 此方法返回重复节点。

下面的例子(clonenode_example.htm)解析XML文档(node.xml)成XML DOM对象,并创建所述第一的深层副本雇员元件。

<!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元素下的每个子元素

执行

将此文件另存为serverpath上的clonenode_example.htm(此文件和node.xml应该在服务器中的同一路径上)。我们将得到如下所示的输出-

Tanmay Patil, 1234567890, tanmaypatil@xyz.com
Taniya Mishra, 1234667898, taniyamishra@xyz.com
Tanisha Sharma, 1234562350, tanishasharma@xyz.com
Tanmay Patil, 1234567890, tanmaypatil@xyz.com

您会注意到第一个Employee元素已完全克隆。

 上一页  打印页面

------分隔线----------------------------
标签(Tag):
------分隔线----------------------------
推荐内容
  • DOM-节点对象

    节点 接口是整个文档对象模型的主要数据类型。 该节点用于表示整个文档树中的单个XML...

  • XML DOM-删除节点

    在本章中,我们将研究XML DOM Remove Node 操作。 删除节点操作将从文档中删除指定的...

  • XML DOM-替换节点

    在本章中,我们将研究XML DOM对象中的替换节点操作。 众所周知,DOM中的所有内容都以...

  • XML DOM-创建节点

    在本章中,我们将讨论如何使用文档对象的几种方法创建新节点。 这些方法提供了创建新 ...

  • XML DOM-获取节点

    在本章中,我们将研究如何获取 XML DOM对象 的 节点 值。 XML文档具有称为节点的信息...

  • XML DOM - Accessing

    在本章中,我们将研究如何访问被视为XML文档信息单元的XML DOM节点。 XML DOM的节点结...

猜你感兴趣