Heim Web-Frontend js-Tutorial Warum wird das Event-Bubbling zweimal ausgelöst?

Warum wird das Event-Bubbling zweimal ausgelöst?

Feb 22, 2024 am 09:06 AM
事件冒泡 点击事件 auslösen zweimal

Warum wird das Event-Bubbling zweimal ausgelöst?

Warum wird das Event Sprudeln zweimal ausgelöst?

Ereignisblasen bedeutet, dass im DOM, wenn ein Element ein Ereignis auslöst (z. B. ein Klickereignis), das Ereignis vom Element zum übergeordneten Element aufsteigt, bis es nach oben zum Dokumentobjekt gelangt. Das Ereignis-Bubbling ist Teil des DOM-Ereignismodells, das es Entwicklern ermöglicht, Ereignis-Listener an übergeordnete Elemente zu binden, sodass, wenn untergeordnete Elemente Ereignisse auslösen, diese Ereignisse erfasst und über den Bubbling-Mechanismus verarbeitet werden können.

Allerdings stoßen Entwickler manchmal auf Situationen, in denen Ereignisse in die Luft sprudeln und zweimal ausgelöst werden, was normalerweise bei verschachtelten Elementen der Fall ist. Um besser zu verstehen, warum es zweimal ausgelöst wird, schauen wir uns ein bestimmtes Codebeispiel an.

HTML-Code lautet wie folgt:

<div id="parent">
  <div id="child">
    <button id="button">点击我</button>
  </div>
</div>
Nach dem Login kopieren

JavaScript-Code lautet wie folgt:

var parent = document.getElementById("parent");
var child = document.getElementById("child");
var button = document.getElementById("button");

parent.addEventListener("click", function(event) {
  console.log("父元素被点击");
});

child.addEventListener("click", function(event) {
  console.log("子元素被点击");
});

button.addEventListener("click", function(event) {
  console.log("按钮被点击");
  event.stopPropagation();
});
Nach dem Login kopieren

Im obigen Code haben wir ein übergeordnetes Element, ein untergeordnetes Element und eine Schaltfläche, die jeweils an Klickereignis-Listener gebunden sind. Wenn wir auf einer Webseite auf eine Schaltfläche klicken, wird das Ereignis gemäß den Bubbling-Regeln vom untergeordneten Element an das übergeordnete Element übergeben.

Jetzt simulieren wir einen Tastenklick. Wenn wir auf die Schaltfläche klicken, gibt die Konsole die folgende Ausgabe aus:

按钮被点击
子元素被点击
Nach dem Login kopieren

Warum wird es zweimal ausgelöst?

Das liegt daran, dass die Ereignissprudelung beim auslösenden Element beginnt und der Reihe nach zum übergeordneten Element aufsteigt und in diesem Prozess zwei Schichten aus untergeordneten Elementen und übergeordneten Elementen durchläuft. Wenn wir auf die Schaltfläche klicken, wird zunächst das Klickereignis der Schaltfläche ausgelöst und „Auf die Schaltfläche wurde geklickt“ wird gedruckt. Dann sprudelt das Ereignis weiter zum untergeordneten Element, löst das Klickereignis des untergeordneten Elements aus und gibt die Meldung „Untergeordnetes Element wurde angeklickt“ aus. Schließlich setzt sich das Sprudeln bis zum übergeordneten Element fort und löst das Klickereignis des übergeordneten Elements aus.

Wie kann man also verhindern, dass das Ereignis zweimal sprudelt und ausgelöst wird?

Wir können verhindern, dass das Ereignis sprudelt, indem wir event.stopPropagation() im Click-Event-Handler der Schaltfläche aufrufen. Im obigen Code haben wir diese Methode im Click-Ereignis der Schaltfläche verwendet. Wenn wir erneut auf die Schaltfläche klicken, gibt die Konsole nur „auf die Schaltfläche geklickt“ aus, ohne weiterhin zu untergeordneten und übergeordneten Elementen zu gelangen. event.stopPropagation()来阻止事件继续冒泡。在上述代码中,我们已经在按钮的点击事件中使用了这个方法。当我们再次点击按钮时,控制台将只打印出"按钮被点击",而不会继续冒泡至子元素和父元素。

总结来说,事件冒泡会触发两次的情况通常出现在嵌套元素中,当一个元素触发了某个事件时,事件会从触发元素开始向上冒泡至父元素,直到冒泡到最顶层的文档对象为止。然而,我们可以通过调用event.stopPropagation()

Zusammenfassend lässt sich sagen, dass das Ereignis-Bubbling in verschachtelten Elementen normalerweise zweimal ausgelöst wird. Wenn ein Element ein Ereignis auslöst, wird das Ereignis vom auslösenden Element zum übergeordneten Element weitergeleitet, bis es zum Dokumentobjekt der obersten Ebene gelangt. Wir können jedoch verhindern, dass das Ereignis sprudelt, indem wir event.stopPropagation() aufrufen und so verhindern, dass das Ereignis zweimal ausgelöst wird. 🎜

Das obige ist der detaillierte Inhalt vonWarum wird das Event-Bubbling zweimal ausgelöst?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Entwickeln Sie leistungsstarke Desktop-Anwendungen mit Golang Entwickeln Sie leistungsstarke Desktop-Anwendungen mit Golang Mar 19, 2024 pm 05:45 PM

Verwenden Sie Golang, um leistungsstarke Desktop-Anwendungen zu entwickeln. Mit der kontinuierlichen Entwicklung des Internets sind Menschen untrennbar mit verschiedenen Arten von Desktop-Anwendungen verbunden. Für Entwickler ist es von entscheidender Bedeutung, effiziente Programmiersprachen zu verwenden, um leistungsstarke Desktop-Anwendungen zu entwickeln. In diesem Artikel wird die Verwendung von Golang (Go-Sprache) zur Entwicklung leistungsstarker Desktop-Anwendungen vorgestellt und einige spezifische Codebeispiele bereitgestellt. Golang ist eine von Google entwickelte Open-Source-Programmiersprache. Sie zeichnet sich durch Einfachheit, Effizienz, starke Parallelität usw. aus und eignet sich sehr gut für

So richten Sie Jump on Laui-Anmeldeseite ein So richten Sie Jump on Laui-Anmeldeseite ein Apr 04, 2024 am 03:12 AM

Schritte zur Sprungeinstellung der Layui-Anmeldeseite: Sprungcode hinzufügen: Fügen Sie im Anmeldeformular ein Beurteilungsereignis hinzu, klicken Sie auf die Schaltfläche „Senden“ und springen Sie nach erfolgreicher Anmeldung über window.location.href zur angegebenen Seite. Ändern Sie die Formularkonfiguration: Fügen Sie dem Formularelement von „lay-filter="login" ein verstecktes Eingabefeld mit dem Namen „redirect“ und dem Wert der Zielseitenadresse hinzu.

So fügen Sie in Vue Berührungsereignisse zu Bildern hinzu So fügen Sie in Vue Berührungsereignisse zu Bildern hinzu May 02, 2024 pm 10:21 PM

Wie füge ich in Vue ein Klickereignis zum Bild hinzu? Importieren Sie die Vue-Instanz. Erstellen Sie eine Vue-Instanz. Fügen Sie Bilder zu HTML-Vorlagen hinzu. Fügen Sie Klickereignisse mit der v-on:click-Direktive hinzu. Definieren Sie die handleClick-Methode in der Vue-Instanz.

Hongmeng HarmonyOS- und Go-Sprachentwicklung Hongmeng HarmonyOS- und Go-Sprachentwicklung Apr 08, 2024 pm 04:48 PM

Einführung in die Sprachentwicklung von HarmonyOS und Go. HarmonyOS ist ein von Huawei entwickeltes verteiltes Betriebssystem, und Go ist eine moderne Programmiersprache. Die Kombination der beiden bietet eine leistungsstarke Lösung für die Entwicklung verteilter Anwendungen. In diesem Artikel wird die Verwendung der Go-Sprache für die Entwicklung in HarmonyOS vorgestellt und das Verständnis anhand praktischer Fälle vertieft. Installation und Einrichtung Um die Go-Sprache zum Entwickeln von HarmonyOS-Anwendungen zu verwenden, müssen Sie zuerst GoSDK und HarmonyOSSDK installieren. Die spezifischen Schritte sind wie folgt: #Installieren Sie GoSDKgogetgithub.com/golang/go#Set PATH

PHP-Tipps: Implementieren Sie schnell die Funktion „Zurück zur vorherigen Seite'. PHP-Tipps: Implementieren Sie schnell die Funktion „Zurück zur vorherigen Seite'. Mar 09, 2024 am 08:21 AM

PHP-Tipps: Implementieren Sie schnell die Funktion zum Zurückkehren zur vorherigen Seite. Bei der Webentwicklung müssen wir häufig die Funktion zum Zurückkehren zur vorherigen Seite implementieren. Solche Vorgänge können das Benutzererlebnis verbessern und Benutzern die Navigation zwischen Webseiten erleichtern. In PHP können wir diese Funktion durch einfachen Code erreichen. In diesem Artikel wird erläutert, wie Sie die Funktion zum Zurückkehren zur vorherigen Seite schnell implementieren können, und es werden spezifische PHP-Codebeispiele bereitgestellt. In PHP können wir $_SERVER['HTTP_REFERER'] verwenden, um die URL der vorherigen Seite abzurufen

Was ist der ereignisgesteuerte Mechanismus von C++-Funktionen in der gleichzeitigen Programmierung? Was ist der ereignisgesteuerte Mechanismus von C++-Funktionen in der gleichzeitigen Programmierung? Apr 26, 2024 pm 02:15 PM

Der ereignisgesteuerte Mechanismus in der gleichzeitigen Programmierung reagiert auf externe Ereignisse, indem er beim Eintreten von Ereignissen Rückruffunktionen ausführt. In C++ kann der ereignisgesteuerte Mechanismus mit Funktionszeigern implementiert werden: Funktionszeiger können Callback-Funktionen registrieren, die beim Eintreten von Ereignissen ausgeführt werden sollen. Lambda-Ausdrücke können auch Ereignisrückrufe implementieren und so die Erstellung anonymer Funktionsobjekte ermöglichen. Im konkreten Fall werden Funktionszeiger verwendet, um Klickereignisse für GUI-Schaltflächen zu implementieren, die Rückruffunktion aufzurufen und Meldungen zu drucken, wenn das Ereignis auftritt.

Detaillierte Erläuterung des Abrufens von Webseitenelementen durch JavaScript Detaillierte Erläuterung des Abrufens von Webseitenelementen durch JavaScript Apr 09, 2024 pm 12:45 PM

Antwort: JavaScript bietet eine Vielzahl von Methoden zum Abrufen von Webseitenelementen, einschließlich der Verwendung von IDs, Tag-Namen, Klassennamen und CSS-Selektoren. Detaillierte Beschreibung: getElementById(id): Elemente basierend auf einer eindeutigen ID abrufen. getElementsByTagName(tag): Ruft die Elementgruppe mit dem angegebenen Tag-Namen ab. getElementsByClassName(class): Ruft die Elementgruppe mit dem angegebenen Klassennamen ab. querySelector(selector): Verwenden Sie den CSS-Selektor, um das erste passende Element abzurufen. querySelectorAll(selector): Alle Übereinstimmungen mithilfe des CSS-Selektors abrufen

Erobern Sie die GUI-Welt mit Python Tkinter: Die vollständige Anleitung Erobern Sie die GUI-Welt mit Python Tkinter: Die vollständige Anleitung Mar 24, 2024 am 09:26 AM

Tkinter ist ein leistungsstarkes GUI-Toolkit in der Python-Standardbibliothek zum Erstellen plattformübergreifender grafischer Benutzeroberflächen (GUIs). Es basiert auf dem Tcl/Tk-Toolkit und bietet eine einfache und intuitive Syntax, sodass Python-Entwickler komplexe Benutzeroberflächen einfach und schnell erstellen können. Vorteile der plattformübergreifenden Kompatibilität von Tkinter: Tkinter-Anwendungen laufen auf allen gängigen Betriebssystemen wie Windows, Mac und Linux. Einfach zu verwenden: Die Syntax ist klar und leicht zu erlernen, sodass sie sowohl für Anfänger als auch für erfahrene Entwickler leicht zu beherrschen ist. Erweiterbarkeit: Tkinter bietet eine Vielzahl von Widgets und Steuerelementen, die es Entwicklern ermöglichen, eine Vielzahl von Benutzeroberflächen zu erstellen. Integration: Es hängt mit P zusammen

See all articles