Heim > Web-Frontend > js-Tutorial > Hauptteil

Ausführliche Erläuterung des Beispielcodes zum Erfassen und Verhindern der Ereignisweitergabe durch Javascript

伊谢尔伦
Freigeben: 2017-07-22 16:41:30
Original
2046 Leute haben es durchsucht

1. Was ist Event-Bubbling?

Im Sortieralgorithmus haben wir die sogenannte Blasensortierung gelernt, um die zugrunde liegenden Dinge an die Oberfläche zu bringen.

Das Nachfolgend sehen wir uns ein Beispiel an, um zu veranschaulichen, was Event-Bubbling ist.


<p>
 <button>测试</button>
</p>
<script>
 $("p").bind("click",function(){alert("p")});
 $("button").bind("click",function(){alert("button"});
</script>
Nach dem Login kopieren
Nach dem Login kopieren

Wenn das Event-Bubbling unterstützt wird und wir auf die Schaltfläche „Testen“ klicken, wird als erstes die Warnung („Schaltfläche“) ausgeführt Name impliziert:

Ereignisse werden in der Reihenfolge vom spezifischsten Ereignisziel zum am wenigsten spezifischen Ereignisziel (Dokumentobjekt) ausgelöst.

Wenn p-, button- und html-Stammelemente alle Ereignisse haben, ist die Reihenfolge der Ereignisausführung:

button->p->html

2. Was ist Ereigniserfassung?

Schauen wir uns noch einmal die Ereigniserfassung an. Im Vergleich zur Ereigniserfassung ist die Reihenfolge der Verarbeitungszeit völlig entgegengesetzt zum Ereignis-Bubbling

Wenn dieser Code ausgeführt wird, wird zuerst Alert("p") und dann Alert("button") ausgeführt. Wir erläutern das Konzept der Ereigniserfassung:


Ereignisse werden ausgehend vom ungenauesten Objekt (Dokumentobjekt) und dann zum genauesten ausgelöst.

<p>
 <button>测试</button>
</p>
<script>
 $("p").bind("click",function(){alert("p")});
 $("button").bind("click",function(){alert("button"});
</script>
Nach dem Login kopieren
Nach dem Login kopieren
Wenn es gebundene Ereignisse für die Elemente button, p und html gibt, ist die Ausführungsreihenfolge der Ereignisse ebenfalls:

html->p->button

3. Was sind die Ereignisverarbeitungsmechanismen verschiedener Browserversionen?

(1) Im DOM wird das Ereignis-Bubbling und die Ereigniserfassung unterstützt. Im W3C-Standard wird davon ausgegangen, dass jedes Ereignis mit der Ereigniserfassung beginnt und den Endknoten findet wird den Wurzelknoten erreichen.

Die Funktionen im DOM, die die Ereignisbindung unterstützen, sind:

Für den userCapture-Parameter ist der Standardwert false und Ereignis-Bubbling wird unterstützt.

Wenn der userCapture-Parameter wahr ist, wird die Ereigniserfassung unterstützt.

(2) Für viele Browser wird die addEventListener-Methode unterstützt, aber IE unterstützt sie nicht!
addEventListener("事件名",函数,userCapture);
Nach dem Login kopieren

(3) Der Ereignisverarbeitungsmechanismus im IE unterstützt nur die Ereignisbindungsmethode

Diese Methode hat zwei Parameter >

4. Wie kann die Ausbreitung des Vorfalls verhindert werden?


Sowohl das Sprudeln von Ereignissen als auch das Erfassen von Ereignissen können blockiert werden.

attachEvent("事件名","函数名")
Nach dem Login kopieren
(1) Erstens lautet die Methode zur Verhinderung der Ereignisausbreitung im W3C: stopPropagation() im IE durch Festlegen von

(2 ) Wie kann das Standardverhalten eines Ereignisses verhindert werden? Verwenden Sie im W3C-Standard die Methode „preventDefault“ und im IE die Einstellung


Das obige ist der detaillierte Inhalt vonAusführliche Erläuterung des Beispielcodes zum Erfassen und Verhindern der Ereignisweitergabe durch Javascript. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!