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>[email protected]</Email>
</Employee>
<Employee category = "Non-Technical">
<FirstName>Max</FirstName>
<LastName>Su</LastName>
<ContactNo>1334667898</ContactNo>
<Email>[email protected]</Email>
</Employee>
<Employee category = "Management">
<FirstName>Min</FirstName>
<LastName>Su</LastName>
<ContactNo>1364562350</ContactNo>
<Email>[email protected]</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>
執行上面範例程式碼,得到以下結果 -