目次
イベントの伝播を正確に制御する:特定の要素のイベントのリスニングを選択的にキャンセルする
解決策:イベント委任を巧みに使用します
コードの例
原則分析
ホームページ ウェブフロントエンド jsチュートリアル イベントの伝播中に特定の要素を聞くイベントを選択的にキャンセルする方法は?

イベントの伝播中に特定の要素を聞くイベントを選択的にキャンセルする方法は?

Apr 04, 2025 pm 01:57 PM
html要素

イベントの伝播中に特定の要素を聞くイベントを選択的にキャンセルする方法は?

イベントの伝播を正確に制御する:特定の要素のイベントのリスニングを選択的にキャンセルする

特に、ネストされた要素に複数のイベントリスナーが存在する場合、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>

ログイン後にコピー

原則分析

  1. イベントデリゲート:親要素Aでイベントリスナーをバインドすることにより、子要素ACのイベントの監視が達成されます。 event.target.idは、イベントの特定のトリガー要素を識別するために使用されます。

  2. Selectiveブロッキング: B -Elementのカスタムリスナーでは、 event.stopImmediatePropagation()メソッドを使用します。このメソッドは、イベントが要素Bでさらに伝播するのを防ぐため、要素Bの組み込みリスニング機能の実行を防ぎますが、イベントは親要素Aまでバブルアップし続けることで、要素Aのリスナーをトリガーします。

この方法により、イベントの伝播を正確に制御し、ネストされた要素のイベントリスニングを効果的に処理し、不必要な競合を回避できます。

以上がイベントの伝播中に特定の要素を聞くイベントを選択的にキャンセルする方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

onclickを使用してPHP関数を実行する onclickを使用してPHP関数を実行する Feb 29, 2024 pm 04:31 PM

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

ExcelデータをHTMLで読み込む方法 ExcelデータをHTMLで読み込む方法 Mar 27, 2024 pm 05:11 PM

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

JSのappendChildとappendの違い JSのappendChildとappendの違い Feb 20, 2024 pm 06:57 PM

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

CSS Transform を使用して要素を変換する CSS Transform を使用して要素を変換する Feb 24, 2024 am 10:09 AM

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

Dreamweaver の改行とは何ですか? Dreamweaver の改行とは何ですか? Apr 08, 2024 pm 09:54 PM

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

jQuery は、要素内に子要素があるかどうかを判断する簡単なメソッドを実装します。 jQuery は、要素内に子要素があるかどうかを判断する簡単なメソッドを実装します。 Feb 28, 2024 pm 03:21 PM

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

CSSでリッジは何を意味しますか CSSでリッジは何を意味しますか Apr 28, 2024 pm 04:06 PM

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

CSSでホバーを使う方法 CSSでホバーを使う方法 Feb 23, 2024 pm 12:06 PM

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

See all articles