


Spezifische Implementierung von js, die das Anhängen von Javascript-Ereignissen verhindert
May 16, 2016 pm 04:34 PMManchmal können Sie e.stopPropagation(); e.preventDefault(); verwenden, um das Sprudeln von Ereignissen und die Ausführung von Standardereignissen zu verhindern. Es kann jedoch nicht verhindern, dass das Ereignis hinzugefügt wird.
Unter welchen Umständen sollten wir das Hinzufügen von Ereignissen verhindern?
Zum Beispiel:
Klicken Sie dabei auf „Zur Kasse gehen“. Der Checkout selbst hat sein eigenes Ereignis, aber Sie müssen festlegen, ob Sie sich vor dem Checkout anmelden möchten.
Wir könnten schreiben:
Js-Code
if(isLogin){ //Bestimmen Sie, ob Sie sich anmelden möchten
console.log("Nicht angemeldet")
}else{
//Checkout-bezogener Code
}
Wenn Sie auf „Meine Homepage“ klicken, erfolgt auch eine Login-Prüfung
Login-Beurteilungscode
if(isLogin){ //Bestimmen Sie, ob Sie sich anmelden möchten
console.log("Nicht angemeldet")
}else{
//Persönliches Zentrum
}
Ob es weitere Anmeldungen gibt, ist zu beurteilen. Wird es mehr Code wie den oben genannten geben? Später entdeckte ich die Methode stopImmediatePropagation(), um das Anhängen von Ereignissen zu verhindern. Das obige Problem ist kein Problem mehr.
Wichtig: Stellen Sie sicher, dass das Login-Beurteilungsereignis das erste gebundene Ereignis ist.
Democode
<!DOCTYPE html> <html> <head lang="de"> <meta charset="UTF-8"> <title>demo</title> <script src="http://lib.sinaapp.com/js/jquery/1.7.2/jquery.min.js"></script> </head> <Körper>
<a href="#" class="bill isLogin">Zur Kasse </a>
<ul> <li class="a1 isLogin">Zu Favoriten hinzufügen</li> <li class="a2 isLogin">Bezahlen durch andere</li> <li class="a3">In den Warenkorb legen</li> <li class="a4 isLogin">Meine Homepage</li> </ul>
<script> //Zuerst binden
$(".isLogin").on("click", function (e) {
if(true){ //Login-Urteil
Alert("Nicht angemeldet");
e.stopImmediatePropagation();
}
return false;
});
$(".bill").on("click",function(){
warning("Zur Kasse gehender Inhalt!");
});
$(".a1").on("click",function(){
alarm("a1");
});
$(".a2").on("click",function(){
alarm("a2");
});
$(".a3").on("click",function(){
Alert("Zum Warenkorb hinzugefügt");
});
$(".a4").on("click",function(){
Alert("Login-Ermittlung");
});
</script> </body> </html>
Tatsächlich stellt uns jquery die Methode $._data($('.isLogin').get(0)) zur Verfügung, mit der wir Ereignisse anzeigen, Firebug öffnen und in die Konsole eingeben können.
Js-Code
$._data($('.isLogin').get(0))
Sie werden Folgendes sehen:
Js-Code
Object { events={...}, handle=function()}
Klicken Sie, um das Ereignisarray anzuzeigen, sodass Sie leicht erkennen können, welche Ereignisse an das Element gebunden sind.

Heißer Artikel

Hot-Tools-Tags

Heißer Artikel

Heiße Artikel -Tags

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Ersetzen Sie Stringzeichen in JavaScript

Benutzerdefinierte Google -Search -API -Setup -Tutorial

8 atemberaubende JQuery -Seiten -Layout -Plugins

Erstellen Sie Ihre eigenen AJAX -Webanwendungen

Verbessern Sie Ihr JQuery -Wissen mit dem Quell Betrachter

10 Mobile Cheat Sheets für die mobile Entwicklung
