¿Existe una función como document.getElementById("FirstDiv").clear()
?¿Cómo puedo eliminar un nodo secundario en HTML usando JavaScript?
Respuesta
Para responder a la pregunta original - hay varias maneras de hacer esto, pero la siguiente sería el más simple
Si ya tiene un identificador para el nodo hijo que desea eliminar, es decir, tiene una variable de JavaScript que contiene una referencia a ella:
myChildNode.parentNode.removeChild(myChildNode);
Obviamente, si usted no está utilizando una de las numerosas bibliotecas que ya hacen esto, usted quiere crear una función para abstraer esto:
function removeElement(node) {
node.parentNode.removeChild(node);
}
EDIT: Como se ha mencionado por otros: si tiene cualquier controlador de eventos cableado al nodo que está eliminando, querrá asegurarse de desconectarlos antes de que la última referencia al nodo que se está eliminando quede fuera del alcance, para que las implementaciones deficientes del intérprete de JavaScript no tengan memoria.
Por "implementaciones deficientes". ¿Te refieres a IE6, IE7, IE8 o algo más? (en particular, ¿los buenos navegadores pierden memoria también? Actualmente no me importa para IE 6-7.) –
@CamiloMartin - no estoy seguro de los detalles en estos días, pero por lo que recuerdo, los 'buenos' navegadores se supone que deben vigilar esas cosas y manejarlas. YMMV –
Bueno, eso tiene sentido. –
Debería poder utilizar el método .RemoveNode del nodo o el método .RemoveChild del nodo primario.
removeNode es solo IE. –
Si desea borrar el div y quitar todos los nodos secundarios, se puede poner:
var mydiv = document.getElementById('FirstDiv');
while(mydiv.firstChild) {
mydiv.removeChild(mydiv.firstChild);
}
probablemente debería utilizar una biblioteca JavaScript para hacer cosas como esta.
Por ejemplo, MochiKit tiene una función removeElement, y jQuery tiene remove.
usted tiene que quitar cualquier controlador de eventos que se ha fijado en el nodo antes de retirarla, para evitar pérdidas de memoria en el IE
¿Se filtra IE8 también? –
Una solución jQuery
HTML
<select id="foo">
<option value="1">1</option>
<option value="2">2</option>
<option value="3">3</option>
</select>
Javascript
// remove child "option" element with a "value" attribute equal to "2"
$("#foo > option[value='2']").remove();
// remove all child "option" elements
$("#foo > option").remove();
Referencias:
Attribute Equals Selector [name=value]
Selecciona elementos que tienen el atributo especificado con un valor exactamente igual a un cierto valor.
Child Selector (“parent > child”)
Selecciona todos los elementos secundarios directos especificado por "niño" de elementos especificado por "padre"
similares a .empty (), el .remove() método toma elementos del DOM. Usamos .remove() cuando queremos eliminar el elemento en sí, así como todo dentro de él. Además de los elementos en sí mismos, todos los eventos vinculados y los datos jQuery asociados con los elementos se eliminan.
utilizar el siguiente código:
//for Internet Explorer
document.getElementById("FirstDiv").removeNode(true);
//for other browsers
var fDiv = document.getElementById("FirstDiv");
fDiv.removeChild(fDiv.childNodes[0]); //first check on which node your required node exists, if it is on [0] use this, otherwise use where it exists.
targetNode.remove()
Esto es recomendado por el W3C en los últimos tiempos 2015, y es vainilla JS. Mucho mejor/más limpio que el método anterior.
Por su caso de uso:
document.getElementById("FirstDiv").remove();
Si necesita un polyfill para asegurar la compatibilidad hacia atrás:
if (!('remove' in Element.prototype)) {
Element.prototype.remove = function() {
if (this.parentNode) {
this.parentNode.removeChild(this);
}
};
}
var p=document.getElementById('childId').parentNode;
var c=document.getElementById('childId');
p.removeChild(c);
alert('Deleted');
p es nodo padre y C es nodo hijo
parentNode es una Variable de JavaScript que contiene la referencia principal
Fácil de entender
- 1. ¿Cómo puedo determinar si el nodo seleccionado es un nodo secundario o secundario en TreeView?
- 2. ¿Cómo puedo eliminar entidades HTML usando Guava?
- 3. JsTree Abra un nodo y luego seleccione un nodo secundario (usando json_result)
- 4. Cómo eliminar un objeto secundario en NHibernate?
- 5. primer nombre de nodo secundario en xslt
- 6. ¿Cómo puedo leer un comentario HTML ubicado fuera de <html> usando JavaScript?
- 7. NodeJS: proceso del nodo secundario?
- 8. eliminar nodo html de htmldocument: HTMLAgilityPack
- 9. Cómo leer el atributo de un nodo primario desde un nodo secundario en XSLT
- 10. ¿Cómo seleccionar el primer nombre secundario de un nodo? XPath
- 11. ¿Cómo recorro un nodo XML en JavaScript?
- 12. Cómo seleccionar cierto nodo secundario en TreeView, C#
- 13. Compruebe si un nodo xml contiene sub secundario
- 14. eliminar un botón html usando js
- 15. cómo obtener el nodo hijo en div usando javascript
- 16. ¿Cómo puedo crear un menú en HTML sin usar Javascript?
- 17. jquery selectores: búsqueda de un elemento secundario del nodo raíz
- 18. ¿Cómo puedo obtener un Nodo adyacente a un Nodo único usando Scala?
- 19. xRuta/HTML: Elija un nodo basado en el nodo relacionado
- 20. ¿Cómo descargar un javascript de un html?
- 21. XPath: Obtener nodos donde nodo secundario contiene un atributo
- 22. usando XPath para encontrar el nodo en un nodo contextual no funciona (firefox/firebug/javascript)
- 23. ¿Cómo puedo mostrar un formulario en un monitor secundario?
- 24. Cómo encontrar un nodo en un árbol con JavaScript
- 25. ¿Cómo puedo registrar un elemento HTML como un objeto JavaScript?
- 26. ¿Cómo eliminar el código emoji usando javascript?
- 27. Cómo eliminar subdominios de dominios usando javascript
- 28. ¿Cómo eliminar espacios en blanco adicionales usando javascript o jquery?
- 29. ¿Cómo puedo adjuntar "metadatos" a un nodo DOM?
- 30. Cómo agregar un elemento secundario a un nodo específico en el árbol n-array?
'node.remove();' es la forma moderna de hacerlo. 'document.getElementById (" FirstDiv "). remove();' para su caso de uso – Gibolt