JavaScript におけるイベント バブリング メカニズムの詳細な分析

JavaScript におけるイベント バブリング メカニズムの詳細な分析

バブリングとは何ですか?

DOM イベント フローには、イベント キャプチャ ステージ、ターゲット ステージ、イベント バブリング ステージの 3 つのステージがあります。

イベントキャプチャ: 簡単に言えば、マウスがクリックされたり、DOM イベントがトリガーされたりすると、ブラウザはルートノードのイベントを外側から内側に伝播します。つまり、子要素がクリックされた場合、親要素がイベントキャプチャを通じて対応するイベントを登録していれば、親要素にバインドされたイベントが最初にトリガーされます。

イベント バブリング (バブリングとも呼ばれる): イベント キャプチャとは対照的に、イベント バブリングは内部からルート ノードへのイベント伝播です。

DOM 標準イベント フローのトリガー順序は、最初にキャプチャしてからバブリングします。つまり、DOM イベントがトリガーされると、最初にイベントがキャプチャされ、イベント ソースがキャプチャされた後、イベントがイベント伝播を通じてバブリングされます。ブラウザによって実装は異なります。IE10 以下ではキャプチャ イベントがサポートされていないため、イベント キャプチャ ステージが 1 つ少なくなります。IE11、Chrome、Firefox、Safari などのブラウザにはすべてこの機能があります。

addEventListener() メソッド

このメソッドはイベント リスナーを設定し、特定のイベントが発生したときに指定されたパラメータを使用してアクションを実行します。構文は次のとおりです。

イベントリスナーを追加します(イベント、関数、キャプチャの使用)

パラメータ event は必須であり、クリック、タッチスタートなど、プレフィックス on のないイベントなど、監視対象のイベントを示します。

イベントがトリガーされた後に呼び出される関数を示す関数パラメータも必須です。これは外部で定義された関数または匿名関数にすることができます。

パラメーター useCapture はオプションです。イベントがバブリングかキャプチャーかを示すために、true または false を入力できます。true はキャプチャーを意味し、デフォルトの false はバブリングを意味します。

イベントリスナーを削除する

addEventListener() によって追加されたイベント リスナーを削除する場合は、removeEventListener() を使用する必要があります。構文は次のとおりです。

removeEventListener(イベント、関数)

パラメータはaddEventListener()と同じです。

互換性

IE 8 以前、および Opera 7.0 以前では、addEventListener() メソッドと removeEventListener() メソッドはサポートされていません。代わりに次のメソッドを使用します。

イベントを追加します:

アタッチイベント(イベント、関数)

イベントを削除:

**detachEvent(イベント、関数)**

互換性の問題は、次の方法で解決できます。

div1.addEventListener の場合 {
         div1.addEventListener('click', 関数() {
             console.log("サポート")
         });
} そうでない場合 (div1.attachEvent) {
         div1.attachEvent('onclick', 関数() {
             console.log("サポートされていません")
         });
}

バブリングとキャプチャーの具体的な違い

html

    <div id="div1">
         <div id="div2"></div>
    </div>

JS

<スクリプト>
        var div1 = document.getElementById("div1");
        div2 要素を取得します。
        div1.addEventListener('click',function(){
            console.log("div1--キャプチャフェーズ")
        }、真実);
        div2.addEventListener('click',function(){
            console.log("div2--キャプチャフェーズ")
        }、真実);
        div1.addEventListener('click',function(){
            console.log("div1--バブルステージ")
        });
        div2.addEventListener('click',function(){
            console.log("div2--バブルステージ")
        });
</スクリプト>

出力結果(div2をクリックしたときの実行結果)

解決

関数stopBubble(e) {
         e && e.stopPropagation の場合 {
                e.stopPropagation(); //W3CのstopPropagation()メソッドをサポートします } else {
             window.event.cancelBubble = true; // それ以外の場合は、IE のメソッドを使用してイベントのバブリングをキャンセルする必要があります}
}

要約する

JavaScript のイベント バブリング メカニズムに関するこの記事はこれで終わりです。JavaScript イベント バブリングに関するより関連性の高いコンテンツについては、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • js におけるイベントバブリングとイベントキャプチャの簡単な分析
  • JS でのイベント バブリングとイベント キャプチャの概要
  • JSバブリングイベントとイベントキャプチャ例の詳細な説明
  • jsイベント委譲の詳細な説明
  • JavaScriptはイベントリスナーをイベント委任にバッチで追加します。詳細なプロセス
  • JavaScript イベントバブリング、イベントキャプチャ、イベント委任の詳細な説明

<<:  Linux ログ内のキーワードとその前後の情報を検索する方法の例

>>:  CentOS7 に MySQL データベースをインストールしてデバッグする詳細な手順 [例]

推薦する

Windows 上で Nginx+Tomcat クラスタを実装するプロセスの分析

導入: Nginx (エンジン エックスと同じ発音) は、BSD のようなプロトコルに基づいてリリー...

Dockerコマンドの学習を1つの記事にまとめる

目次導入ミラーリポジトリログイン引く押す検索ローカル画像管理画像rmiタグ建てる歴史保存負荷輸入コン...

MySQL での limit の使用方法は何ですか (推奨)

SELECT * FROM テーブル名制限m,n; SELECT * FROM テーブル LIMI...

CSSの記述形式、モバイルページの基本構造の詳細な説明

1. CSSの記述形式1. インラインスタイルCSSコードを開始タグに直接記述することができます&l...

Jenkins は Docker イメージを構築し、Harbor ウェアハウスにプッシュします

目次DockerファイルドキュメントJenkins の設定Spring Boot プロジェクトでは、...

Douyin ロゴを作成する手順の CSS3 分析

「Tik Tok」も大人気で、ユーザー数は7億人と言われています。今日は、注目を集めるためにTikT...

MySQLデータベースの使用仕様の概要

導入: MySQL データベースの仕様に関しては、皆さんも何らかのドキュメントを読んだことがあると思...

Centos7.5でのIPアドレス設定の実装

1. IPアドレスを設定する前に、まずifconfigを使用してネットワークカード情報を表示し、ネッ...

指定された期間内のすべての日付または月を取得する MySQL ステートメント (ストアド プロシージャの設定やテーブルの追加は不要)

mysql は期間内のすべての日付または月を取得します1: mysqlは期間内のすべての月を取得し...

Alibaba Cloud CentOS 7 に MySQL 8.0.13 をインストールする方法

1. MySQL インストール パッケージをダウンロードします(ここにはコツがあります。おそらく、こ...

Windows 2008 Server サブドメインを親ドメインに追加すると、ドメインが既に存在するというエラー メッセージが表示されます。

Windows 2008 Serverのサブドメインを親ドメインに参加させると、「ドメインは既に存...

MySQL 5.7.11 zip インストールと設定方法のグラフィックチュートリアル

1. MySQL 5.7.11 zipインストールパッケージをダウンロードするこのマシンはwin7 ...

Reactのref属性を深く理解する方法

目次概要1. Refsオブジェクトの作成1.1 React.createRef() 1.2React...

JavaScript インタビュー: 配列の平坦化メソッドを実装する方法

目次1 配列のフラット化とは何ですか? 2 JS標準ライブラリの配列フラット化メソッド3 フラットメ...

Dockerは指定されたメモリで操作を実行します

次のように: -m, --memory メモリ制限。形式は数値と単位です。単位は b、k、m、g の...