Heim > Web-Frontend > js-Tutorial > Direkte vs. delegierte Ereignisbehandlung in jQuery: Wann sollte ich welche verwenden?

Direkte vs. delegierte Ereignisbehandlung in jQuery: Wann sollte ich welche verwenden?

Susan Sarandon
Freigeben: 2024-12-25 04:47:17
Original
695 Leute haben es durchsucht

Direct vs. Delegated Event Handling in jQuery: When Should I Use Which?

Direkte vs. delegierte Ereignisbehandlung mit jQuery .on()

Bei Verwendung der jQuery .on()-Methode für die Ereignisbehandlung gibt es ist ein grundlegender Unterschied zwischen direkten und delegierten Ereignishandlern.

Direkte Ereignishandler hängen, wie der Name schon sagt, Ereignis-Listener direkt an bestimmte Ereignisse an Elemente. Beispiel:

$("div#target span.green").on("click", function() {
   alert($(this).attr("class") + " is clicked");
});
Nach dem Login kopieren

In diesem Szenario ist der Click-Event-Listener direkt an jedes span.green-Element im div#target-Container gebunden.

Delegierte Event-Handler hingegen , hängen Sie Ereignis-Listener an ein übergeordnetes Element an und delegieren Sie die Verarbeitung von Ereignissen an untergeordnete Elemente, die einem Selektor entsprechen. Zum Beispiel:

$("div#target").on("click", "span.green", function() {
   alert($(this).attr("class") + " is clicked");
});
Nach dem Login kopieren

Hier wird der Click-Event-Listener an den div#target-Container angehängt, der dann die Verarbeitung von Klicks an alle untergeordneten span.green-Elemente delegiert.

Der Schlüssel Der Unterschied besteht darin, dass bei der delegierten Ereignisbehandlung der Handler nicht aufgerufen wird, wenn das Ereignis direkt im übergeordneten Element auftritt. Stattdessen sprudelt das Ereignis im DOM-Baum nach oben und der Handler wird nur für untergeordnete Elemente aufgerufen, die mit dem bereitgestellten Selektor übereinstimmen. Dies kann für dynamische Inhalte von Vorteil sein, bei denen neue Elemente hinzugefügt oder entfernt werden können, da der Ereignis-Listener automatisch auf alle übereinstimmenden Nachkommen angewendet wird, ohne dass eine explizite Bindung erforderlich ist.

Im bereitgestellten Beispiel sowohl direkte als auch delegierte Ereignisse Handler führen zum gleichen Verhalten, da keine dynamischen Elemente hinzugefügt oder entfernt werden. Wenn jedoch neue span.green-Elemente dynamisch zur Seite hinzugefügt würden, würde nur der delegierte Ereignishandler ihre Klickereignisse verarbeiten.

Das obige ist der detaillierte Inhalt vonDirekte vs. delegierte Ereignisbehandlung in jQuery: Wann sollte ich welche verwenden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage