Heim > Web-Frontend > js-Tutorial > Wie hänge ich Event-Handler mit jQuery an dynamisch hinzugefügte Elemente an?

Wie hänge ich Event-Handler mit jQuery an dynamisch hinzugefügte Elemente an?

Patricia Arquette
Freigeben: 2025-01-05 11:10:43
Original
157 Leute haben es durchsucht

How to Attach Event Handlers to Dynamically Added Elements with jQuery?

So binden Sie Ereignisse mit jQuery an dynamische Elemente

Angenommen, Sie verfügen über vorhandenen jQuery-Code, der Ereignishandler an Elemente mit der Klasse .myclass anhängt . In Szenarien, in denen diese Elemente jedoch dynamisch über AJAX oder DHTML zur Seite hinzugefügt werden, ist den neu erstellten Elementen nicht der Klick-Handler zugeordnet.

Problemlösung

Um dieses Problem zu lösen, bietet jQuery mehrere Ansätze:

1. .on()-Methode (jQuery 1.7):

Ersetzen Sie die .live()-Methode durch .on() und geben Sie einen Selektor an, der das übergeordnete Element mit .myclass als Argument kombiniert.

$('body').on('click', 'a.myclass', function() {
    // do something
});
Nach dem Login kopieren

Dadurch wird der Click-Handler an alle angehängt. Tags mit der Klasse .myclass, unabhängig davon, wann sie der Seite hinzugefügt werden.

2. .delegate()-Methode (jQuery 1.6 - 1.8):

Die .delegate()-Methode verhält sich ähnlich wie .on(), erfordert jedoch die Angabe des übergeordneten Elements in Klammern:

$('body').delegate('a.myclass', 'click', function() {
    // do something
});
Nach dem Login kopieren

Sowohl .on() als auch .delegate() ermöglichen die Ereignisbehandlung für dynamisch hinzugefügte Elemente.

Das obige ist der detaillierte Inhalt vonWie hänge ich Event-Handler mit jQuery an dynamisch hinzugefügte Elemente an?. 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