Heim > Web-Frontend > js-Tutorial > Wie verhindert man die Ereignisweitergabe in JavaScript mithilfe von Inline-OnClick?

Wie verhindert man die Ereignisweitergabe in JavaScript mithilfe von Inline-OnClick?

Susan Sarandon
Freigeben: 2024-12-07 10:30:16
Original
977 Leute haben es durchsucht

How to Prevent Event Propagation in JavaScript using Inline onclick?

Verhindern der Ereignisweitergabe mit Inline-Onclick-Attribut

Ereignisweitergabe bezieht sich auf die Kaskadenwirkung von Ereignissen durch den DOM-Baum. Wenn ein Ereignis auf einem inneren Element auftritt, breitet es sich normalerweise auf die übergeordneten Elemente aus. In bestimmten Szenarien kann es wünschenswert sein, diese Ausbreitung zu stoppen, um unbeabsichtigtes Verhalten zu verhindern.

Bedenken Sie den folgenden HTML-Code:

<div onclick="alert('you clicked the header')" class="header">
  <span onclick="alert('you clicked inside the header');">something inside the header</span>
</div>
Nach dem Login kopieren

Wenn ein Benutzer irgendwo innerhalb des Element werden sowohl die Klick-Handler des Spans als auch des Divs ausgelöst. Möglicherweise möchten wir jedoch verhindern, dass das Klickereignis des Div ausgelöst wird, wenn der Benutzer mit seinem untergeordneten Element interagiert.

Um dies zu erreichen, können wir die Methode event.stopPropagation() verwenden. Diese Funktion verhindert effektiv, dass das Ereignis in seine übergeordneten Elemente übergeht. Hier ist der geänderte Code:

<span onclick="event.stopPropagation(); alert('you clicked inside the header');">something inside the header</span>
Nach dem Login kopieren

Wenn der Benutzer nun auf klickt; Element wird nur sein eigenes Klickereignis ausgelöst. Das Klickereignis des Divs wird nicht mehr ausgelöst.

IE-Kompatibilität

Beachten Sie, dass ältere Versionen von Internet Explorer (IE) event.stopPropagation() nicht nativ unterstützen. Stattdessen müssen wir window.event.cancelBubble = true:

<span onclick="window.event.cancelBubble = true; alert('you clicked inside the header');">something inside the header</span>
Nach dem Login kopieren
verwenden

Das obige ist der detaillierte Inhalt vonWie verhindert man die Ereignisweitergabe in JavaScript mithilfe von Inline-OnClick?. 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