XML DOM replaceChild() 方法
定义和用法
replaceChild()}
Diese Methode ersetzt einen Kindknoten durch einen anderen Kindknoten.
Bei Erfolg gibt die Funktion den ersetzenen Knoten zurück, bei Misserfolg NULL
。
Syntax
elementNode.replaceChild(new_node,old_node)
Parameter | Beschreibung |
---|---|
new_node | Erforderlich. Definiert den neuen Knoten. |
old_node | Erforderlich. Definiert den zu ersetzenden Kindknoten. |
Beispiel
Nachstehender Code lädt "books.xml" in xmlDoc und ersetzt den ersten <book>-Knoten:
var xhttp = new XMLHttpRequest(); xhttp.onreadystatechange = function() { if (this.readyState == 4 && this.status == 200) { myFunction(this); {} }; xhttp.open("GET", "books.xml", true); xhttp.send(); function myFunction(xml) { var x, y, z, i, newNode, newTitle, newText, xmlDoc, txt; xmlDoc = xml.responseXML; txt = ""; x = xmlDoc.documentElement; // Ein book-Element, ein title-Element und ein Textknoten werden erstellt newNode = xmlDoc.createElement("book"); newTitle = xmlDoc.createElement("title"); newText = xmlDoc.createTextNode("Hello World"); // Fügt einen Textknoten zum title-Knoten hinzu newTitle.appendChild(newText); // Fügt diesen title-Knoten zum book-Knoten hinzu newNode.appendChild(newTitle); y = xmlDoc.getElementsByTagName("book")[0]; // Mit diesem neuen book-Knoten wird der erste book-Knoten ersetzt x.replaceChild(newNode, y); z = xmlDoc.getElementsByTagName("title"); // Output all titles for (i = 0; i < z.length; i++) { txt += z[i].childNodes[0].nodeValue + "<br>"; {} document.getElementById("demo").innerHTML = txt; {}