Maison interface Web js tutoriel Explication détaillée des exemples de délégation d'événements JS

Explication détaillée des exemples de délégation d'événements JS

Mar 13, 2018 pm 02:59 PM
javascript 实例 详解

Cet article partage principalement avec vous l'explication détaillée des exemples de délégation d'événements JS. Voyons d'abord l'analyse de la délégation d'événements : également appelée proxy d'événement, elle utilise le principe du bullage pour ajouter des événements au parent afin de déclencher le. effet d'exécution.

Tout d'abord, vous devez avoir écrit un programme comme celui-ci. Il y a une liste Lorsque la souris se déplace dans chaque li, la couleur de fond devient rouge, nous avons donc écrit ce code :

(Le code que je donne est généralement le code clé, vous pouvez écrire le code HTML par vous-même.)

window.onload =  oUl = document.getElementById('ull' aLi = document.getElementsByTagName('li'); 
    ( i =0;i < aLi.length;i++=
Copier après la connexion

Bien sûr, il n'y a aucun problème si vous regardez le code comme ceci. Vous pouvez. ajoutez des événements à chaque li via une boucle, mais je veux y réfléchir si nous avons beaucoup de li, devons-nous ajouter de nombreux événements, cela consomme en fait beaucoup de performances ? On se demandera alors si on peut y parvenir en ajoutant simplement un événement. Bien sûr que c’est possible, sinon je n’en parlerais pas.

Il s'agit d'une délégation d'événements via le principe de bouillonnement. Nous pouvons ajouter des événements uniquement à l'oUL parent, de sorte que quel que soit le li déplacé, l'événement d'emménagement du parent sera déclenché (pour ceux qui ne le font pas. Je ne comprends pas le bouillonnement, vous pouvez vous référer à mon article sur le bouillonnement JS), mais il y a aussi un problème en ce moment, car mon exigence est de changer la couleur du li correspondant, pas la liste entière. Comment sait-il quel LI I. déplacé la souris vers ? À ce moment-là, un attribut dans l'objet événement universel est sur le point d'apparaître, qui est la source de l'événement (quel que soit l'élément auquel l'événement est lié, il fait référence à la cible qui déclenche réellement l'événement), qui peut obtenez le LI où se trouve actuellement votre souris,

Cependant, cela présente des problèmes de compatibilité. IE est différent du standard La norme fait référence aux versions les plus récentes des navigateurs

IE : window. event.srcElement
Standard : event. target

Il doit donc être compatible, ce qui est également très simple.

Regardez le code global ci-dessous :

window.onload = function(){ 
    var oUl = document.getElementById('ull');     var aLi = document.getElementsByTagName('li');

  oUl.onmouseover = function(ev){ 
     var event = ev||window.event;  // 获取event对象     var target = ev.target || ev.srcElement; // 获取触发事件的目标对象    
     if(target.nodeName.toLowerCase() == 'li'){  //判断目标对象是不是li
         target.style.background = 'red';
     }

  }
代码中加了一个标签名的判断,主要原因是如果不加判断,当你鼠标移入到父级oUL上面的时候,整个列表就会变红,这不是我们想要的结果,所以要判断一下。
Copier après la connexion
target.nodeName 弹出的名字是大写的,所以需要转换大小写再比较。
Copier après la connexion

L'ensemble de l'exigence est complété de cette manière, et les performances sont grandement améliorées lorsqu'il y en a plusieurs listes.

En fait, la délégation d'événements a un deuxième avantage : les éléments nouvellement ajoutés auront également des événements précédents

Supposons que nous ayons une autre exigence, cliquez sur un bouton, vous pouvez en créer une autre li dans la liste. À l'heure actuelle, la méthode générale est que parce que le li nouvellement créé n'a pas d'événement, il n'a pas pour fonction d'entrer et de devenir rouge. Cependant, en utilisant la méthode de délégation d'événement, le nouveau li également. a cet événement. Le principe est également très simple à appliquer, car l'événement est ajouté au père. Si le père est là, l'événement est là. Vous pouvez le tester vous-même.

Recommandations associées :

Détails de ce que sont les événements dans js Bubbling et capture d'événements et délégation d'événements

Analyse comparative de la capture d'événements, du bouillonnement et de la délégation d'événements

Explication détaillée de la délégation d'événements Javascript

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!

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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Explication détaillée de l'obtention des droits d'administrateur dans Win11 Explication détaillée de l'obtention des droits d'administrateur dans Win11 Mar 08, 2024 pm 03:06 PM

Le système d'exploitation Windows est l'un des systèmes d'exploitation les plus populaires au monde et sa nouvelle version Win11 a beaucoup attiré l'attention. Dans le système Win11, l'obtention des droits d'administrateur est une opération importante. Les droits d'administrateur permettent aux utilisateurs d'effectuer davantage d'opérations et de paramètres sur le système. Cet article présentera en détail comment obtenir les autorisations d'administrateur dans le système Win11 et comment gérer efficacement les autorisations. Dans le système Win11, les droits d'administrateur sont divisés en deux types : administrateur local et administrateur de domaine. Un administrateur local dispose de tous les droits d'administration sur l'ordinateur local

Explication détaillée du fonctionnement de la division dans Oracle SQL Explication détaillée du fonctionnement de la division dans Oracle SQL Mar 10, 2024 am 09:51 AM

Explication détaillée de l'opération de division dans OracleSQL Dans OracleSQL, l'opération de division est une opération mathématique courante et importante, utilisée pour calculer le résultat de la division de deux nombres. La division est souvent utilisée dans les requêtes de bases de données. Comprendre le fonctionnement de la division et son utilisation dans OracleSQL est donc l'une des compétences essentielles des développeurs de bases de données. Cet article discutera en détail des connaissances pertinentes sur les opérations de division dans OracleSQL et fournira des exemples de code spécifiques pour référence aux lecteurs. 1. Opération de division dans OracleSQL

Explication détaillée du rôle et de l'utilisation de l'opérateur modulo PHP Explication détaillée du rôle et de l'utilisation de l'opérateur modulo PHP Mar 19, 2024 pm 04:33 PM

L'opérateur modulo (%) en PHP est utilisé pour obtenir le reste de la division de deux nombres. Dans cet article, nous discuterons en détail du rôle et de l'utilisation de l'opérateur modulo et fournirons des exemples de code spécifiques pour aider les lecteurs à mieux comprendre. 1. Le rôle de l'opérateur modulo En mathématiques, lorsqu'on divise un entier par un autre entier, on obtient un quotient et un reste. Par exemple, lorsque l’on divise 10 par 3, le quotient est 3 et le reste est 1. L'opérateur modulo est utilisé pour obtenir ce reste. 2. Utilisation de l'opérateur modulo En PHP, utilisez le symbole % pour représenter le module

Explication détaillée de la fonction d'appel système Linux system() Explication détaillée de la fonction d'appel système Linux system() Feb 22, 2024 pm 08:21 PM

Explication détaillée de la fonction d'appel système Linux system() L'appel système est une partie très importante du système d'exploitation Linux. Il fournit un moyen d'interagir avec le noyau système. Parmi elles, la fonction system() est l’une des fonctions d’appel système couramment utilisées. Cet article présentera en détail l’utilisation de la fonction system() et fournira des exemples de code correspondants. Concepts de base des appels système Les appels système sont un moyen permettant aux programmes utilisateur d'interagir avec le noyau du système d'exploitation. Les programmes utilisateur demandent au système d'exploitation en appelant des fonctions d'appel système

Explication détaillée de la commande Linux curl Explication détaillée de la commande Linux curl Feb 21, 2024 pm 10:33 PM

Explication détaillée de la commande curl de Linux Résumé : curl est un puissant outil de ligne de commande utilisé pour la communication de données avec le serveur. Cet article présentera l'utilisation de base de la commande curl et fournira des exemples de code réels pour aider les lecteurs à mieux comprendre et appliquer la commande. 1. Qu’est-ce que la boucle ? curl est un outil de ligne de commande utilisé pour envoyer et recevoir diverses requêtes réseau. Il prend en charge plusieurs protocoles, tels que HTTP, FTP, TELNET, etc., et fournit des fonctions riches, telles que le téléchargement de fichiers, le téléchargement de fichiers, la transmission de données, le proxy.

En savoir plus sur Promise.resolve() En savoir plus sur Promise.resolve() Feb 18, 2024 pm 07:13 PM

Une explication détaillée de Promise.resolve() nécessite des exemples de code spécifiques. Promise est un mécanisme en JavaScript pour gérer les opérations asynchrones. Dans le développement réel, il est souvent nécessaire de traiter certaines tâches asynchrones qui doivent être exécutées dans l'ordre, et la méthode Promise.resolve() est utilisée pour renvoyer un objet Promise qui a été rempli. Promise.resolve() est une méthode statique de la classe Promise, qui accepte un

Analyse détaillée du parcours d'apprentissage du langage C Analyse détaillée du parcours d'apprentissage du langage C Feb 18, 2024 am 10:38 AM

En tant que langage de programmation largement utilisé dans le domaine du développement de logiciels, le langage C est le premier choix de nombreux programmeurs débutants. L'apprentissage du langage C peut non seulement nous aider à acquérir des connaissances de base en programmation, mais également à améliorer nos capacités de résolution de problèmes et de réflexion. Cet article présentera en détail une feuille de route d'apprentissage du langage C pour aider les débutants à mieux planifier leur processus d'apprentissage. 1. Apprendre la grammaire de base Avant de commencer à apprendre le langage C, nous devons d'abord comprendre les règles de grammaire de base du langage C. Cela inclut les variables et les types de données, les opérateurs, les instructions de contrôle (telles que les instructions if,

Explication détaillée de la méthode de requête de version numpy Explication détaillée de la méthode de requête de version numpy Jan 19, 2024 am 08:20 AM

Numpy est une bibliothèque de calcul scientifique Python qui fournit une multitude de fonctions et d'outils d'opération de tableau. Lors de la mise à niveau de la version Numpy, vous devez interroger la version actuelle pour garantir la compatibilité. Cet article présentera en détail la méthode de requête de version Numpy et fournira des exemples de code spécifiques. Méthode 1 : utilisez le code Python pour interroger la version Numpy Vous pouvez facilement interroger la version Numpy à l'aide du code Python. Voici la méthode d'implémentation et un exemple de code : importnumpyasnpprint(np.

See all articles