XML DOM replaceChild() 方法
定义和用法
replaceChild()
Este método reemplaza un nodo subyacente con otro nodo.
En caso de éxito, esta función devuelve el nodo reemplazado, y en caso de fracaso devuelve NULL
.
Sintaxis
elementNode.replaceChild(new_node,old_node)
Parámetros | Descripción |
---|---|
new_node | Obligatorio. Especifica el nuevo nodo. |
old_node | Obligatorio. Especifica el nodo subyacente que se debe reemplazar. |
Ejemplo
El siguiente código carga "books.xml" en xmlDoc y reemplaza el primer elemento <book>:
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; // Crear un elemento de book, un elemento de title y un nodo de texto newNode = xmlDoc.createElement("book"); newTitle = xmlDoc.createElement("title"); newText = xmlDoc.createTextNode("Hello World"); // Agregar un nodo de texto al nodo de title newTitle.appendChild(newText); // Agregar este nodo de title al nodo de book newNode.appendChild(newTitle); y = xmlDoc.getElementsByTagName("book")[0]; // Usar este nuevo nodo de book para reemplazar el primer nodo de book x.replaceChild(newNode, y); z = xmlDoc.getElementsByTagName("title"); // Salida de todos los title for (i = 0; i < z.length; i++) { txt += z[i].childNodes[0].nodeValue + "<br>"; } document.getElementById("demo").innerHTML = txt; }