XML DOM替換節點
在本章中,我們將學習XML DOM對象中的替換節點操作。DOM中的所有內容都保存在分層信息單元中,替換節點提供了另一種更新這些指定節點或文本節點的方法。
以下是替換節點的兩個方法 -
-
replaceChild()
-
replaceData()
1. replaceChild()方法
replaceChild()
方法用新節點替換指定的節點。
語法
insertData()
具有以下語法 -
Node replaceChild(Node newChild, Node oldChild) throws DOMException
其中,
-
newChild
- 是放入子列表的新節點。 -
oldChild
- 是列表中要替換的節點。 - 此方法返回已替換的節點。
示例
以下示例(replacenode.html)將XML文檔(node.xml)解析爲XML DOM對象,並使用新節點<Name>
替換指定的節點<FirstName>
。
<!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("/node.xml");
x = xmlDoc.documentElement;
z = xmlDoc.getElementsByTagName("FirstName");
document.write("<b>Content of FirstName element before replace operation</b><br>");
for (i=0;i<z.length;i++) {
document.write(z[i].childNodes[0].nodeValue);
document.write("<br>");
}
//create a Employee element, FirstName element and a text node
newNode = xmlDoc.createElement("Employee");
newTitle = xmlDoc.createElement("Name");
newText = xmlDoc.createTextNode("MS Dhoni");
//add the text node to the title node,
newTitle.appendChild(newText);
//add the title node to the book node
newNode.appendChild(newTitle);
y = xmlDoc.getElementsByTagName("Employee")[0]
//replace the first book node with the new node
x.replaceChild(newNode,y);
z = xmlDoc.getElementsByTagName("FirstName");
document.write("<b>Content of FirstName element after replace operation</b><br>");
for (i = 0;i<z.length;i++) {
document.write(z[i].childNodes[0].nodeValue);
document.write("<br>");
}
</script>
</body>
</html>
執行上面示例代碼,得到以下結果 -
2. replaceData()方法
replaceData()
方法用指定的字符串替換從指定的16位單偏移量開始的字符。
語法
replaceData()
具有以下語法 -
void replaceData(int offset, int count, java.lang.String arg) throws DOMException
其中,
-
offset
- 是開始替換的偏移量。 -
count
- 要替換的16
位單元的數量。 如果偏移量和計數之和超過長度,則替換數據末尾的所有16
位單元。 -
arg
- 必須替換的DOMString
字符串範圍。
示例
以下示例(replace_data.html)將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("/node.xml");
x = xmlDoc.getElementsByTagName("ContactNo")[0].childNodes[0];
document.write("<b>ContactNo before replace operation:</b> "+x.nodeValue);
x.replaceData(1,2,"XX");
document.write("<br>");
document.write("<b>ContactNo after replace operation:</b> "+x.nodeValue);
</script>
</body>
</html>
在上面的例子中 -
-
x.replaceData(1,2,"XX");
- 這裏最後一個參數保存指定<ContactNo>
元素的文本,其文本從位置1
開始直到長度:2
由新文本「XX」
替換。
執行上面示例代碼,得到以下結果 -