Maison >interface Web >js tutoriel >Maîtriser la délégation d'événements en JavaScript : simplifier la gestion des événements
Délégation d'événement est une technique en JavaScript où un seul écouteur d'événement est utilisé pour gérer les événements de plusieurs éléments enfants. Cette approche exploite le bullage d'événements pour améliorer les performances et simplifier le code lorsqu'il s'agit d'éléments créés dynamiquement ou de plusieurs éléments similaires.
Au lieu d'attacher des écouteurs d'événement à des éléments enfants individuels, vous attachez un seul écouteur à un élément parent. Cet auditeur capte les événements qui jaillissent de ses enfants.
<ul> <h4> <strong>JavaScript</strong> </h4> <pre class="brush:php;toolbar:false">const menu = document.getElementById("menu"); menu.addEventListener("click", function(event) { if (event.target.tagName === "LI") { console.log("Clicked item:", event.target.textContent); } });
La délégation d'événements est idéale pour gérer des événements sur des éléments ajoutés dynamiquement.
const menu = document.getElementById("menu"); // Adding a new item dynamically const newItem = document.createElement("li"); newItem.textContent = "Blog"; menu.appendChild(newItem); // No need to add a new event listener menu.addEventListener("click", function(event) { if (event.target.tagName === "LI") { console.log("Clicked item:", event.target.textContent); } });
Utilisez stopPropagation() ou des conditions spécifiques pour limiter la gestion des événements.
<ul> <h4> <strong>JavaScript</strong> </h4> <pre class="brush:php;toolbar:false">const menu = document.getElementById("menu"); menu.addEventListener("click", function(event) { if (event.target.tagName === "LI") { console.log("Clicked item:", event.target.textContent); } });
const menu = document.getElementById("menu"); // Adding a new item dynamically const newItem = document.createElement("li"); newItem.textContent = "Blog"; menu.appendChild(newItem); // No need to add a new event listener menu.addEventListener("click", function(event) { if (event.target.tagName === "LI") { console.log("Clicked item:", event.target.textContent); } });
menu.addEventListener("click", function(event) { if (event.target.tagName === "LI") { console.log("Clicked item:", event.target.textContent); } else { event.stopPropagation(); // Stop propagation for non-LI elements } });
<table> <pre class="brush:php;toolbar:false">const table = document.getElementById("dataTable"); table.addEventListener("click", function(event) { if (event.target.tagName === "TD") { console.log("Clicked cell:", event.target.textContent); } });
En maîtrisant la délégation d'événements, vous pouvez écrire du code JavaScript plus propre et plus efficace pour les applications Web interactives.
Bonjour, je m'appelle Abhay Singh Kathayat !
Je suis un développeur full-stack avec une expertise dans les technologies front-end et back-end. Je travaille avec une variété de langages et de frameworks de programmation pour créer des applications efficaces, évolutives et conviviales.
N'hésitez pas à me contacter à mon e-mail professionnel : kaashshorts28@gmail.com.
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!