DOM Node对象cloneNode()
方法用于在派生类中重写时创建重复节点。它返回重复的节点。
语法
以下是cloneNode()
方法的使用语法。
nodeObject.cloneNode(boolean deep)
参数
deep
- 如果为true
,则以递归方式克隆指定节点下的子树; 如果为false
,则仅克隆节点本身(及其属性,如果它是元素)。
返回值
- 此方法返回重复的节点。
示例
文件:node.xml 的内容如下 -
<Company>
<Employee category = "Technical" id = "firstelement">
<FirstName>Susen</FirstName>
<LastName>Su</LastName>
<ContactNo>1584567890</ContactNo>
<Email>susen@yiibai.com</Email>
</Employee>
<Employee category = "Non-Technical">
<FirstName>Max</FirstName>
<LastName>Su</LastName>
<ContactNo>1334667898</ContactNo>
<Email>maxsu@yiibai.com</Email>
</Employee>
<Employee category = "Management">
<FirstName>Min</FirstName>
<LastName>Su</LastName>
<ContactNo>1364562350</ContactNo>
<Email>minsu@yiibai.com</Email>
</Employee>
</Company>
以下示例演示了cloneNode
方法的用法,文件:clonenode.html -
<!DOCTYPE html>
<html>
<meta charset="utf-8"/>
<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("/node.xml");
x = xmlDoc.getElementsByTagName('Employee')[0];
clone_node = x.cloneNode(true);
xmlDoc.documentElement.appendChild(clone_node);
document.write("以下列表已克隆节点: ");
document.write("<br>");
y = xmlDoc.getElementsByTagName("FirstName");
for (i = 0; i < y.length; i ++)
{
document.write(y[i].childNodes[0].nodeValue);
document.write("<br>");
}
</script>
</body>
</html>
执行上面示例代码,得到以下结果 -