Maison interface Web js tutoriel Comprendre et mettre en œuvre les principes et méthodes de bouillonnement et de capture d'événements

Comprendre et mettre en œuvre les principes et méthodes de bouillonnement et de capture d'événements

Jan 13, 2024 pm 12:47 PM
事件冒泡 capture d'événement Mise en œuvre du principe

Comprendre et mettre en œuvre les principes et méthodes de bouillonnement et de capture dévénements

Le principe et la mise en œuvre du bouillonnement d'événements et de la capture d'événements

Le bouillonnement d'événements (Event Bubbling) et la capture d'événements (Event Capturing) sont deux mécanismes différents en JavaScript pour gérer les événements DOM (Document Object Model). Comprendre leurs principes et leur mise en œuvre peut nous aider à mieux comprendre et gérer les événements.

Principe du bouillonnement d'événements :
Le bouillonnement d'événements signifie que lorsqu'un événement spécifique se produit sur un certain élément DOM, si l'élément définit une fonction de gestionnaire pour l'événement, l'événement sera d'abord déclenché sur l'élément, puis bouillonnera jusqu'au élément parent de l'élément jusqu'à ce que la fonction de gestionnaire de l'élément racine du document soit déclenchée.

Méthode d'implémentation :
En JavaScript, nous pouvons utiliser la méthode addEventListener pour ajouter des écouteurs d'événements aux éléments afin d'obtenir un bouillonnement d'événements.
Ce qui suit est un exemple :

// HTML代码:
<div id="outer">
  <div id="inner">
    <button id="btn">按钮</button>
  </div>
</div>

// JavaScript代码:
const outer = document.querySelector('#outer');
const inner = document.querySelector('#inner');
const btn = document.querySelector('#btn');

outer.addEventListener('click', function() {
  console.log('外层div被点击!');
});

inner.addEventListener('click', function() {
  console.log('内层div被点击!');
});

btn.addEventListener('click', function(event) {
  console.log('按钮被点击!');
  event.stopPropagation(); // 阻止事件冒泡
});
Copier après la connexion

Dans le code ci-dessus, lorsque nous cliquons sur le bouton, l'événement bouillonnant sera déclenché étape par étape vers le haut à partir de l'élément le plus interne, en exécutant d'abord le gestionnaire d'événement de clic du bouton, puis l'événement du div interne La fonction de gestionnaire, et enfin la fonction de gestionnaire d'événements du div externe.

Principe de la capture d'événements : 
La capture d'événements est l'opposé du bouillonnement d'événements. La capture d'événements signifie commencer à partir de l'élément racine du document et parcourir chaque élément de l'arborescence DOM jusqu'à ce qu'un événement spécifique soit déclenché.

Méthode d'implémentation :
De même, nous pouvons utiliser la méthode addEventListener pour ajouter des écouteurs d'événements aux éléments afin de réaliser la capture d'événements.
Ce qui suit est un exemple :

// HTML代码:
<div id="outer">
  <div id="inner">
    <button id="btn">按钮</button>
  </div>
</div>

// JavaScript代码:
const outer = document.querySelector('#outer');
const inner = document.querySelector('#inner');
const btn = document.querySelector('#btn');

outer.addEventListener('click', function() {
  console.log('外层div被点击!');
}, true);

inner.addEventListener('click', function() {
  console.log('内层div被点击!');
}, true);

btn.addEventListener('click', function() {
  console.log('按钮被点击!');
}, true);
Copier après la connexion

Dans le code ci-dessus, lorsque nous cliquons sur le bouton, l'événement démarrera à partir de l'élément racine du document et sera déclenché étape par étape vers le bas. Le gestionnaire d'événements du div externe sera exécuté. d'abord, puis le gestionnaire d'événements du div interne sera exécuté. La fonction de gestionnaire d'événements, et enfin la fonction de gestionnaire d'événements de clic du bouton est exécutée.

Résumé : 
Le bouillonnement d'événements et la capture d'événements sont deux mécanismes différents pour gérer les événements DOM en JavaScript. Ils propagent les événements dans différentes directions le long de l'arborescence DOM. La diffusion d'événements commence à partir de l'élément déclencheur et remonte jusqu'à l'élément racine du document ; la capture d'événements commence à partir de l'élément racine du document et se propage jusqu'à l'élément déclencheur. Nous pouvons utiliser la méthode addEventListener pour ajouter un écouteur d'événement à un élément et définir s'il faut utiliser la capture d'événement ou le bouillonnement dans le troisième paramètre.

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

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

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)

Comprendre le mécanisme de bouillonnement d'événements : Pourquoi un clic sur un élément enfant affecte-t-il l'événement de l'élément parent ? Comprendre le mécanisme de bouillonnement d'événements : Pourquoi un clic sur un élément enfant affecte-t-il l'événement de l'élément parent ? Jan 13, 2024 pm 02:55 PM

Comprendre le bouillonnement d'événements : pourquoi un clic sur un élément enfant déclenche-t-il un événement sur l'élément parent ? Le bouillonnement d'événements signifie que dans une structure d'éléments imbriqués, lorsqu'un élément enfant déclenche un événement, l'événement sera transmis à l'élément parent couche par couche comme un bouillonnement, jusqu'à l'élément parent le plus à l'extérieur. Ce mécanisme permet aux événements sur les éléments enfants de se propager dans toute l'arborescence des éléments et de déclencher tour à tour tous les éléments associés. Pour mieux comprendre le bouillonnement d'événements, examinons un exemple de code spécifique. Code HTML : <divid="parent&q

Pourquoi le bouillonnement d'événements se déclenche-t-il deux fois ? Pourquoi le bouillonnement d'événements se déclenche-t-il deux fois ? Feb 22, 2024 am 09:06 AM

Pourquoi le bouillonnement d'événements se déclenche-t-il deux fois ? Le bouillonnement d'événement (Event Bubbling) signifie que dans le DOM, lorsqu'un élément déclenche un événement (comme un événement de clic), l'événement bouillonne de l'élément vers l'élément parent jusqu'à ce qu'il bouillonne vers l'objet document de niveau supérieur. La diffusion d'événements fait partie du modèle d'événement DOM, qui permet aux développeurs de lier des écouteurs d'événements aux éléments parents, de sorte que lorsque des éléments enfants déclenchent des événements, ceux-ci puissent être capturés et traités via le mécanisme de diffusion. Cependant, les développeurs rencontrent parfois des événements qui se déclenchent deux fois.

Raisons et solutions de l'échec de jQuery .val() Raisons et solutions de l'échec de jQuery .val() Feb 20, 2024 am 09:06 AM

Titre : Raisons et solutions de l'échec de jQuery.val() Dans le développement front-end, jQuery est souvent utilisé pour faire fonctionner des éléments DOM. La méthode .val() est largement utilisée pour obtenir et définir la valeur des éléments de formulaire. Cependant, nous rencontrons parfois des situations où la méthode .val() échoue, entraînant l'incapacité d'obtenir ou de définir correctement la valeur de l'élément de formulaire. Cet article explorera les causes de l'échec de .val(), fournira les solutions correspondantes et joindra des exemples de code spécifiques. 1.Méthode d'analyse des causes.val()

Pourquoi l'événement click dans js ne peut-il pas être exécuté à plusieurs reprises ? Pourquoi l'événement click dans js ne peut-il pas être exécuté à plusieurs reprises ? May 07, 2024 pm 06:36 PM

Les événements de clic en JavaScript ne peuvent pas être exécutés à plusieurs reprises en raison du mécanisme de propagation des événements. Pour résoudre ce problème, vous pouvez prendre les mesures suivantes : Utiliser la capture d'événement : Spécifiez un écouteur d'événement à déclencher avant que l'événement ne se déclenche. Remise des événements : utilisez event.stopPropagation() pour arrêter le bouillonnement des événements. Utilisez une minuterie : déclenchez à nouveau l'écouteur d'événements après un certain temps.

Pour quels scénarios les modificateurs d'événements dans vue peuvent-ils être utilisés ? Pour quels scénarios les modificateurs d'événements dans vue peuvent-ils être utilisés ? May 09, 2024 pm 02:33 PM

Les modificateurs d'événements Vue.js sont utilisés pour ajouter des comportements spécifiques, notamment : empêcher le comportement par défaut (.prevent) arrêter le bouillonnement d'événements (.stop) événement ponctuel (.once) capturer l'événement (.capture) écouter passivement les événements (.passive) Adaptatif modificateur (.self)Modificateur de touche (.key)

Pourquoi le mécanisme de bouillonnement d'événements se déclenche-t-il deux fois ? Pourquoi le mécanisme de bouillonnement d'événements se déclenche-t-il deux fois ? Feb 25, 2024 am 09:24 AM

Pourquoi le bouillonnement d’événements se produit-il deux fois de suite ? La diffusion d'événements est un concept important dans le développement Web. Cela signifie que lorsqu'un événement est déclenché dans un élément HTML imbriqué, l'événement remonte de l'élément le plus interne vers l'élément le plus externe. Ce processus peut parfois prêter à confusion. Un problème courant est que la diffusion d'événements se produit deux fois de suite. Afin de mieux comprendre pourquoi le bouillonnement d'événements se produit deux fois de suite, regardons d'abord un exemple de code :

Quels événements JS ne bouillonnent pas ? Quels événements JS ne bouillonnent pas ? Feb 19, 2024 pm 09:56 PM

Quelles sont les situations dans les événements JS qui ne bouillonneront pas ? Le bouillonnement d'événements (Event Bubbling) signifie qu'après le déclenchement d'un événement sur un certain élément, l'événement sera transmis vers le haut le long de l'arborescence DOM, de l'élément le plus interne à l'élément le plus externe. Cette méthode de transmission est appelée bouillonnement d'événements. Cependant, tous les événements ne peuvent pas surgir. Il existe des cas particuliers dans lesquels les événements ne surgissent pas. Cet article présentera les situations en JavaScript dans lesquelles les événements ne bouillonneront pas. 1. Utilisez stopPropagati

Qu'est-ce que le bouillonnement d'événements ? Analyse approfondie du mécanisme de bouillonnement des événements Qu'est-ce que le bouillonnement d'événements ? Analyse approfondie du mécanisme de bouillonnement des événements Feb 20, 2024 pm 05:27 PM

Qu’est-ce que le bouillonnement d’événements ? Analyse approfondie du mécanisme de diffusion d'événements. La diffusion d'événements est un concept important dans le développement Web, qui définit la manière dont les événements sont diffusés sur la page. Lorsqu'un événement sur un élément est déclenché, l'événement sera transmis à partir de l'élément le plus interne et transmis vers l'extérieur jusqu'à ce qu'il soit transmis à l'élément le plus externe. Cette méthode de livraison est comme des bulles bouillonnant dans l’eau, c’est pourquoi on l’appelle bouillonnement événementiel. Dans cet article, nous analyserons en profondeur le mécanisme de bouillonnement d’événements. Le principe du bouillonnement d’événements peut être compris à travers un exemple simple. Supposons que nous ayons un H

See all articles