Maison >interface Web >js tutoriel >Discussion détaillée sur la délégation d'événements JavaScript
La délégation d'événements est une technique avancée qui rend la gestion des événements DOM en JavaScript plus efficace et plus simple. Habituellement, lorsque nous attachons un gestionnaire d'événements, il est directement associé à un élément DOM spécifique. Mais lorsqu'il existe de nombreux éléments enfants, attacher un gestionnaire d'événements distinct pour chacun est inutile et peu efficace en termes de mémoire. C'est là que la délégation événementielle s'avère utile.
La délégation d'événements fonctionne essentiellement sur la base du mécanisme "Event Bubbling". Grâce à ce mécanisme, l'événement se propage vers le haut depuis sa cible prévue (vers les éléments parents) jusqu'à ce qu'il atteigne le document.
Le bouillonnement d'événement est un processus dans lequel un événement part de son élément cible le plus interne et atteint progressivement ses éléments parents. Supposons que vous cliquiez sur un En utilisant la délégation d'événements, nous attachons un écouteur d'événement à l'élément parent et pouvons également gérer les événements des éléments enfants via le bouillonnement d'événements. Gestion des événements de clic sur une liste simple Supposons que j'ai une liste contenant de nombreux éléments li. Cliquer sur chaque élément li affichera un message. Dans ce code, un écouteur d'événement est ajouté uniquement à l'élément ul. Chaque fois que l'on clique sur un élément li, l'événement apparaîtra dans ul, et nous saurons grâce à event.target que le clic s'est produit sur quel élément li. ধরা যাক, উপরের উদাহরণে আমরা DOM-এ নতুন li item যোগ করব এবং তাদের ক্লিক ইভেন্ট হ্যান্ডল করব। এখানে, আমরা একটি নতুন li item যোগ করার জন্য একটি বাটন যুক্ত করেছি। যখনই একটি নতুন item যোগ করা হবে, সেই item-এ ক্লিক করলে ul element-এ অ্যাটাচ করা ইভেন্ট লিসেনার তার ক্লিক ইভেন্টটি হ্যান্ডল করবে, এবং একটি মেসেজ দেখাবে। ইভেন্ট ডেলিগেশন ছাড়া একই কাজ করা হলে কী সমস্যা হতো? এই কোডে, প্রত্যেকটি li item-এ আলাদাভাবে ইভেন্ট লিসেনার যোগ করা হচ্ছে। কিন্তু এই পদ্ধতি বেশি মেমোরি ব্যবহার করে এবং যদি নতুন li item যোগ করা হয়, তখন সেই item-এ আলাদাভাবে ইভেন্ট লিসেনার অ্যাটাচ করতে হবে। ইভেন্ট ডেলিগেশন এই সমস্যাগুলো দূর করতে পারে। ইভেন্ট ডেলিগেশন একটি শক্তিশালী এবং কার্যকর টেকনিক যা আপনাকে জাভাস্ক্রিপ্টে DOM ইভেন্ট ম্যানেজমেন্টের ক্ষেত্রে সহজ, পরিষ্কার, এবং মেমোরি সাশ্রয়ী কোড লিখতে সাহায্য করে। এটি parent elements-এর ইভেন্ট লিসেনার ব্যবহার করে child elements-এর ইভেন্টগুলোকে হ্যান্ডল করার মাধ্যমে ডাইনামিক কনটেন্ট ম্যানেজমেন্টকেও সহজ করে তোলে। 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!
Comment fonctionne la délégation événementielle ?
Par exemple:
htmlCopy code
<ul id="my-list">
<li>Item 1</li>
<li>Item 2</li>
<li>Item 3</li>
</ul>
<script>
const myList = document.getElementById('my-list');
// ইভেন্ট ডেলিগেশন ব্যবহার করে parent <ul> element-এ ইভেন্ট লিসেনার যোগ করা হলো
myList.addEventListener('click', (e)=> {
e.preventDefault();
// নিশ্চিত করা হচ্ছে যে ক্লিকটি <li> element এ হয়েছে
if (event.target.tagName === 'LI') {
alert('You clicked on ' + event.target.textContent);
}
});
</script>
ইভেন্ট ডেলিগেশন কেন প্রয়োজন?
htmlCopy code
<button id="add-item">Add Item</button>
<ul id="my-list">
<li>Item 1</li>
<li>Item 2</li>
</ul>
<script>
const myList = document.getElementById('my-list');
const addItemButton = document.getElementById('add-item');
let itemCount = 2;
addItemButton.addEventListener('click', (e)=>{
e.preventDefault();
itemCount++;
const newItem = document.createElement('li');
newItem.textContent = 'Item ' + itemCount;
myList.appendChild(newItem);
});
myList.addEventListener('click', function(event) {
if (event.target.tagName === 'LI') {
alert('You clicked on ' + event.target.textContent);
}
});
</script>
htmlCopy code
<ul id="my-list">
<li>Item 1</li>
<li>Item 2</li>
</ul>
<script>
// প্রত্যেকটি <li> element এ আলাদাভাবে ইভেন্ট লিসেনার যোগ করা হচ্ছে
const items = document.querySelectorAll('#my-list li');
items.forEach(function(item) {
item.addEventListener('click', function() {
alert('You clicked on ' + item.textContent);
});
});
</script>
উপসংহার
Articles Liés
Voir plus