Maison > interface Web > js tutoriel > Comment puis-je supprimer efficacement des éléments par ID en JavaScript ?

Comment puis-je supprimer efficacement des éléments par ID en JavaScript ?

Susan Sarandon
Libérer: 2024-12-29 06:13:13
original
945 Les gens l'ont consulté

How Can I Efficiently Remove Elements by ID in JavaScript?

Suppression d'éléments par ID en JavaScript : une alternative pratique

En JavaScript, la méthode standard pour supprimer un élément nécessite de parcourir jusqu'à son nœud parent :

var element = document.getElementById("element-id");
element.parentNode.removeChild(element);
Copier après la connexion

Cette approche nécessite une étape supplémentaire pour accéder au parent, ce qui peut s'avérer inefficace. Cet article explore une alternative qui simplifie la suppression des éléments en ajoutant une méthode Remove au prototype Element.

En étendant les prototypes Element et NodeList, vous pouvez introduire la méthode Remove à tous les éléments et collections HTML :

Element.prototype.remove = function() {
    this.parentElement.removeChild(this);
}
NodeList.prototype.remove = HTMLCollection.prototype.remove = function() {
    for(var i = this.length - 1; i >= 0; i--) {
        if(this[i] && this[i].parentElement) {
            this[i].parentElement.removeChild(this[i]);
        }
    }
}
Copier après la connexion

Avec cet ajout, vous pouvez désormais supprimer des éléments directement :

document.getElementById("my-element").remove();
Copier après la connexion
Copier après la connexion

Ou pour plusieurs éléments :

document.getElementsByClassName("my-elements").remove();
Copier après la connexion

Remarque : Cette solution n'est pas prise en charge par IE 7 et versions antérieures.

Mise à jour (2019) : Node.js a introduit la fonction node.remove(), rendant la suppression d'éléments encore plus simple :

document.getElementById("my-element").remove();
Copier après la connexion
Copier après la connexion

Ou pour collections :

[...document.getElementsByClassName("my-elements")].map(n => n && n.remove());
Copier après la connexion

Cette approche mise à jour est largement prise en charge par les navigateurs modernes, notamment Chrome, Firefox, Edge et Safari.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal