Heim Web-Frontend js-Tutorial Warum ist das von jquery mithilfe von Click gebundene Ereignis ungültig?

Warum ist das von jquery mithilfe von Click gebundene Ereignis ungültig?

Jun 27, 2017 am 10:14 AM
click jquery Warum 使用

jqueryDas durch Klicken gebundene Ereignis ist ungültig

$(this).children(":last").prev().after("<div class=&#39;bounty-add&#39;><a target=&#39;_blank&#39; href=&#39;bounties.php#/p=add&XID=" + playerId + "&#39;>[Bounty]</a></div>"); 
$(this).children(":last").prev().after("<div class=&#39;info-add&#39;><a href=&#39;#&#39;>[Refresh]</a></div>");        
$("div.bounty-add").css(addStyle);
$("div.info-add").css(addStyle);
         
         
$(this).children(":last").prev().children("a").click(function() {
   alert("Hello");
});
Nach dem Login kopieren

Der relevante Basiscode ist wie oben. Die Aktualisierung eines Elements kann jedoch reibungslos abgerufen werden Es ist gebunden. Das Click-Ereignis ist ungültig und in den „Ereignis-Listenern“ von „Elements“ in den „Entwicklertools“ von Chrome kann keine gültige Bindung gefunden werden.
Das durch den obigen Basiscode hinzugefügte DOM ist jeweils gültig. Schleifen, aber ich bin der Meinung, dass es keine Auswirkungen haben sollte. Alle Codes können reibungslos ausgeführt werden, einschließlich des Bindungsschritts . Selbst wenn Sie nach Abschluss der Ausführung auf das a-Element klicken, funktioniert es nicht und Sie können die daran gebundene Funktion nicht finden. . . . . . .

$(this).children(":last").prev().children("a").on("click",function() {
   alert("Hello");
});
Nach dem Login kopieren
Nach dem Login kopieren

auf Ich habe es auch versucht, aber es hat nicht funktioniert. Es scheint, dass diese beiden im Grunde das Gleiche sind?
Da das a-Element selbst über das anklickbare -Attribut verfügt, reagiert es nach dem Klicken immer noch auf sein ursprüngliches Ereignis, z. B. href='#', und am Ende wird ein # hinzugefügt Adressleiste. . . . Ich frage mich, ob es daran liegt, dass das ursprüngliche Ereignis das später hinzugefügte Ereignis überschreibt. . . . . .

Ihre vorherige Bindung war

$(this).children(":last").prev().children("a").on("click",function() {
   alert("Hello");
});
Nach dem Login kopieren
Nach dem Login kopieren

dieselbe wie eine normale Klickbindung
Versuchen Sie es mit einer Bindung wie dieser

$(this).on("click",".info-add a",function() {
   alert("Hello");
});
Nach dem Login kopieren

Ihr Element Wird es dynamisch generiert?
Wenn ja, verwenden Sie Live- oder Delegate-Bindung

Live jquery1.9 hat es entfernt. Nun liegt es nicht daran, dass das Element nicht gefunden werden kann oder nicht gebunden werden kann, sondern dass es nach der Bindung ungültig ist.
Ich habe das a-Element direkt in das p-Element geändert, das auch in Click-Listenern enthalten ist, aber alter("hello"); kann auf keinen Fall ausgelöst werden. . . . . .

Verwenden Sie zunächst Firebug, um zu sehen, ob auf der Seite ein Skriptfehler vorliegt.
Stellen Sie erneut sicher, dass Ihr Code das a-Element findet.
Zum Schluss. Sie können

$(document).on("click",".info-add",function(){
alert("ok")
})
Nach dem Login kopieren

verwenden. Wenn das nicht funktioniert, senden Sie mir bitte den vollständigen Code

Das obige ist der detaillierte Inhalt vonWarum ist das von jquery mithilfe von Click gebundene Ereignis ungültig?. 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

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

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)

Bedarf die Produktion von H5 -Seiten eine kontinuierliche Wartung? Bedarf die Produktion von H5 -Seiten eine kontinuierliche Wartung? Apr 05, 2025 pm 11:27 PM

Die H5 -Seite muss aufgrund von Faktoren wie Code -Schwachstellen, Browserkompatibilität, Leistungsoptimierung, Sicherheitsaktualisierungen und Verbesserungen der Benutzererfahrung kontinuierlich aufrechterhalten werden. Zu den effektiven Wartungsmethoden gehören das Erstellen eines vollständigen Testsystems, die Verwendung von Versionstools für Versionskontrolle, die regelmäßige Überwachung der Seitenleistung, das Sammeln von Benutzern und die Formulierung von Wartungsplänen.

Warum müssen Sie Vue.use (Vuerouter) in der Datei idex.js unter dem Router -Ordner anrufen? Warum müssen Sie Vue.use (Vuerouter) in der Datei idex.js unter dem Router -Ordner anrufen? Apr 05, 2025 pm 01:03 PM

Die Notwendigkeit der Registrierung von Vuerouter in der Datei index.js -Datei im Ordner Router Bei der Entwicklung von VUE -Anwendungen stoßen Sie häufig Probleme mit der Routing -Konfiguration. Besonders...

Kann JS ohne H5 laufen? Kann JS ohne H5 laufen? Apr 06, 2025 am 09:06 AM

Ist JavaScript ohne HTML5 verfügbar? Die JavaScript -Engine selbst kann unabhängig laufen. Das Ausführen von JavaScript in einer Browserumgebung hängt von HTML5 ab, da es die standardisierte Umgebung bietet, die zum Laden und Ausführen von Code erforderlich ist. Die von HTML5 bereitgestellten APIs und Funktionen sind für moderne JavaScript -Frameworks und Bibliotheken von entscheidender Bedeutung. Ohne HTML5 -Umgebungen sind viele JavaScript -Funktionen schwer zu implementieren oder können nicht implementiert werden.

Warum werden die lila abgeschnittenen Bereiche im Flex -Layout fälschlicherweise als 'Überlaufraum' betrachtet? Warum werden die lila abgeschnittenen Bereiche im Flex -Layout fälschlicherweise als 'Überlaufraum' betrachtet? Apr 05, 2025 pm 05:51 PM

Fragen zu lila Schrägstrichen in Flex -Layouts Bei der Verwendung von Flex -Layouts können Sie auf einige verwirrende Phänomene stoßen, wie beispielsweise in den Entwicklerwerkzeugen (D ...

Warum können benutzerdefinierte Stilblätter auf lokalen Webseiten in Safari, nicht jedoch auf Baidu -Seiten wirksam? Warum können benutzerdefinierte Stilblätter auf lokalen Webseiten in Safari, nicht jedoch auf Baidu -Seiten wirksam? Apr 05, 2025 pm 05:15 PM

Diskussion über die Verwendung benutzerdefinierter Stylesheets in Safari heute Wir werden eine Frage zur Anwendung von benutzerdefinierten Stylesheets für Safari Browser diskutieren. Front-End-Anfänger ...

Was sind die Vorteile der H5 -Seitenproduktion Was sind die Vorteile der H5 -Seitenproduktion Apr 05, 2025 pm 11:48 PM

Die Vorteile der H5 -Seitenproduktion umfassen: Leichte Erfahrung, schnelle Ladegeschwindigkeit und Verbesserung der Benutzerbindung. Die plattformübergreifende Kompatibilität ist nicht erforderlich, um sich an verschiedene Plattformen anzupassen und die Entwicklungseffizienz zu verbessern. Flexibilität und dynamische Updates, kein Audit erforderlich, was die Änderung und Aktualisierung von Inhalten erleichtert. Kosteneffektive, niedrigere Entwicklungskosten als native Apps.

Ich kann mich nicht als Stamm bei MySQL anmelden Ich kann mich nicht als Stamm bei MySQL anmelden Apr 08, 2025 pm 04:54 PM

Die Hauptgründe, warum Sie sich bei MySQL nicht als Root anmelden können, sind Berechtigungsprobleme, Konfigurationsdateifehler, Kennwort inkonsistent, Socket -Dateiprobleme oder Firewall -Interception. Die Lösung umfasst: Überprüfen Sie, ob der Parameter Bind-Address in der Konfigurationsdatei korrekt konfiguriert ist. Überprüfen Sie, ob die Root -Benutzerberechtigungen geändert oder gelöscht und zurückgesetzt wurden. Stellen Sie sicher, dass das Passwort korrekt ist, einschließlich Fall- und Sonderzeichen. Überprüfen Sie die Einstellungen und Pfade der Socket -Dateiberechtigte. Überprüfen Sie, ob die Firewall Verbindungen zum MySQL -Server blockiert.

Warum wird ein bestimmtes Div -Element im Edge -Browser nicht angezeigt? Wie löst ich dieses Problem? Warum wird ein bestimmtes Div -Element im Edge -Browser nicht angezeigt? Wie löst ich dieses Problem? Apr 05, 2025 pm 08:21 PM

Wie löst ich das durch User Agent Style Sheets verursachte Anzeigeproblem? Bei Verwendung des Edge -Browsers kann ein Div -Element im Projekt nicht angezeigt werden. Nachdem ich nachgesehen hatte, habe ich gepostet ...

See all articles