イベントの伝播中に特定の要素を聞くイベントを選択的にキャンセルする方法は?
イベントの伝播を正確に制御する:特定の要素のイベントのリスニングを選択的にキャンセルする
特に、ネストされた要素に複数のイベントリスナーが存在する場合、HTML要素イベントを処理する場合、イベント伝播の正確な制御が重要です。この記事では、他の要素のリスナーが適切に動作できるようにしながら、特定の要素のイベントリスナー(例えば、変更されていないリスナーが含まれていない要素)を実行する方法を示します。
次のHTML構造があるとします。
<div id="a"> <div id="b"> <div id="c"></div> </div> </div>
要素A、B、およびCはすべて、クリックイベントの複数のリスニング関数に結合されます。ここでは、要素Bには直接変更できない組み込みのリスニング関数が含まれています。私たちの目標は、要素Bの組み込みリスニング機能のみを防ぎ、要素AとCのリスニング機能を実行し続けることです。
解決策:イベント委任を巧みに使用します
イベントデリゲートは、イベントリスナーを親要素に拘束することにより、子供のイベント伝播を制御する効率的なイベント処理メカニズムです。
コードの例
<meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>イベント処理の例</title> <style> #A, #B, #C { padding: 20px; border: 1px solid black; margin: 10px; } #A { background-color: lightblue; } #B { background-color: lightgreen; } #C { background-color: lightcoral; } </style> <div id="A"> a <div id="B"> b <div id="C">c</div> </div> </div> <script> // 将A和C元素的监听函数绑定到父元素A上 document.getElementById('A').addEventListener('click', function(event) { if (event.target.id === 'A') { console.log('A 元素被点击'); } else if (event.target.id === 'C') { console.log('C 元素被点击'); } }); // 为B元素添加自定义监听函数,阻止事件进一步传播 document.getElementById('B').addEventListener('click', function(event) { event.stopImmediatePropagation(); // 阻止B元素内置监听函数执行 console.log('B 元素自定义监听函数执行'); }); </script>
原則分析
イベントデリゲート:親要素
A
でイベントリスナーをバインドすることにより、子要素A
とC
のイベントの監視が達成されます。event.target.id
は、イベントの特定のトリガー要素を識別するために使用されます。Selectiveブロッキング:
B
-Elementのカスタムリスナーでは、event.stopImmediatePropagation()
メソッドを使用します。このメソッドは、イベントが要素B
でさらに伝播するのを防ぐため、要素B
の組み込みリスニング機能の実行を防ぎますが、イベントは親要素A
までバブルアップし続けることで、要素A
のリスナーをトリガーします。
この方法により、イベントの伝播を正確に制御し、ネストされた要素のイベントリスニングを効果的に処理し、不必要な競合を回避できます。
以上がイベントの伝播中に特定の要素を聞くイベントを選択的にキャンセルする方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











Jquery ライブラリを使用して onclick() イベントを通じて PHP 関数を実行する別の方法についても説明します。このメソッドは JavaScript 関数を呼び出し、php 関数の内容を Web ページに出力します。また、純粋な JavaScript を使用して PHP 関数を呼び出す、onclick() イベントを使用して PHP 関数を実行する別の方法も示します。この記事では、PHP関数を実行し、GETメソッドを使用してURL内のデータを送信し、isset()関数を使用してGETデータを確認する方法を紹介します。このメソッドは、データが設定され、関数が実行されると、PHP 関数を呼び出します。 jQuery を使用して onclick() イベントを通じて PHP 関数を実行することができます。

Excel データを HTML で読み取る方法: 1. JavaScript ライブラリを使用して Excel データを読み取ります; 2. サーバーサイド プログラミング言語を使用して Excel データを読み取ります。

JS の appendChild と append の違いには、具体的なコード例が必要です。JavaScript では、子要素を DOM (ドキュメント オブジェクト モデル) に動的に追加する必要がある場合、通常、appendChild メソッドと append メソッドを使用します。これらの目的は親要素に子要素を追加することですが、使用方法にはいくつかの違いがあります。 1. appendChild メソッド appendChild メソッドは、DOM ノードオブジェクトのメソッドの 1 つです。

CSS での Transform の使用 CSS の Transform プロパティは、HTML 要素の移動、回転、拡大縮小、傾斜などの操作を実行できる非常に強力なツールです。要素の外観を劇的に変更し、Web ページをよりクリエイティブでダイナミックにすることができます。この記事では、Transform のさまざまな使用方法を詳しく紹介し、具体的なコード例を示します。 1. 移動 (Translate) 移動とは、要素を x 軸および y 軸に沿って指定された距離だけ移動することを指します。その構文は次のとおりです。

Dreamweaver の <br> タグを使用して改行を作成します。改行は、メニュー、ショートカット キー、または直接入力によって挿入できます。 CSS スタイルと組み合わせて、特定の高さの空の行を作成できます。場合によっては、段落間に空白行が自動的に作成され、スタイル制御が適用されるため、<br> タグの代わりに <p> タグを使用する方が適切な場合があります。

jQuery は、HTML 要素を操作するための便利なメソッドを多数提供する、広く使用されている JavaScript ライブラリです。 Web ページの開発プロセスでは、要素内にサブ要素があるかどうかを判断する必要がある状況によく遭遇します。この記事では、この機能を実現するための jQuery の使用方法と具体的なコード例を紹介します。要素内に子要素があるかどうかを確認するには、jQuery の Children() メソッドを使用できます。 Children() メソッドは一致を取得するために使用されます。

リッジは CSS の境界線スタイルで、隆起した尾根状の線として現れるエンボス効果のある 3D 境界線を作成するために使用されます。

CSS の hover 疑似クラスは、マウスが要素上にあるときに要素のスタイルを変更できるようにする非常に一般的に使用されるセレクターです。この記事では、ホバーの使い方を紹介し、具体的なコード例を示します。 1. 基本的な使用法 hover を使用するには、まず要素のスタイルを定義し、次に :hover 疑似クラスを使用して、マウスがホバーしているときに対応するスタイルを指定する必要があります。たとえば、ボタン要素があるとすると、ボタンの上にマウスを置くと、ボタンの背景色が赤に、テキストの色が白に変わります。
