バブリングとは何ですか?DOM イベント フローには、イベント キャプチャ ステージ、ターゲット ステージ、イベント バブリング ステージの 3 つのステージがあります。 イベントキャプチャ: 簡単に言えば、マウスがクリックされたり、DOM イベントがトリガーされたりすると、ブラウザはルートノードのイベントを外側から内側に伝播します。つまり、子要素がクリックされた場合、親要素がイベントキャプチャを通じて対応するイベントを登録していれば、親要素にバインドされたイベントが最初にトリガーされます。 イベント バブリング (バブリングとも呼ばれる): イベント キャプチャとは対照的に、イベント バブリングは内部からルート ノードへのイベント伝播です。 DOM 標準イベント フローのトリガー順序は、最初にキャプチャしてからバブリングします。つまり、DOM イベントがトリガーされると、最初にイベントがキャプチャされ、イベント ソースがキャプチャされた後、イベントがイベント伝播を通じてバブリングされます。ブラウザによって実装は異なります。IE10 以下ではキャプチャ イベントがサポートされていないため、イベント キャプチャ ステージが 1 つ少なくなります。IE11、Chrome、Firefox、Safari などのブラウザにはすべてこの機能があります。 addEventListener() メソッドこのメソッドはイベント リスナーを設定し、特定のイベントが発生したときに指定されたパラメータを使用してアクションを実行します。構文は次のとおりです。
パラメータ event は必須であり、クリック、タッチスタートなど、プレフィックス on のないイベントなど、監視対象のイベントを示します。 イベントがトリガーされた後に呼び出される関数を示す関数パラメータも必須です。これは外部で定義された関数または匿名関数にすることができます。 パラメーター useCapture はオプションです。イベントがバブリングかキャプチャーかを示すために、true または false を入力できます。true はキャプチャーを意味し、デフォルトの false はバブリングを意味します。 イベントリスナーを削除する addEventListener() によって追加されたイベント リスナーを削除する場合は、removeEventListener() を使用する必要があります。構文は次のとおりです。
パラメータはaddEventListener()と同じです。 互換性 IE 8 以前、および Opera 7.0 以前では、addEventListener() メソッドと removeEventListener() メソッドはサポートされていません。代わりに次のメソッドを使用します。 イベントを追加します:
イベントを削除:
互換性の問題は、次の方法で解決できます。 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 をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
<<: Linux ログ内のキーワードとその前後の情報を検索する方法の例
>>: CentOS7 に MySQL データベースをインストールしてデバッグする詳細な手順 [例]
このチュートリアルでは、MySQL 5.7.18のインストールと設定方法を参考までに紹介します。具体...
テーブル構造を設計する場合、数値型は最も一般的な型の 1 つですが、数値型をうまく使用するのは想像す...
この記事では、例を使用して、MySQL ユーザー権限を確認および管理する方法を説明します。ご参考まで...
centos-DVD1バージョンシステムの固定IPアドレスは192.168.159.128で、cen...
障害サイト: MySQL サーバーにログインし、どのコマンドを実行してもこのエラーが発生します my...
この記事では、例を使用して MySQL カスタム関数の使用方法を説明します。ご参考までに、詳細は以下...
1.コンテナ内の /etc/hosts、/etc/resolv.conf、/etc/hostname...
1. Baidu Eslint Ruleプラグインをインストールする npm i -D eslint...
目次プロジェクトの作成プロジェクト構造メイン.jsアプリ.vue:設定コンポジションAPI参照反応的...
目次1. 基本的な例2. インスタンスプロトタイプのスコープを設定する3. グローバル変数の登録と使...
目次1. uuid関数を使用して、一意かつ不規則な主キーIDを生成します。 2. idの自動成長1....
適用シナリオ: シールのさまざまな状態に応じて、さまざまな状態のシールの数をカウントする必要がありま...
目次1. useStateフック2. useRefフック3. useRef と useState 4...
この記事では、スローモーションアニメーション効果を実現するためのJavaScriptの具体的なコード...
現在、CSS プリプロセッサは Web 開発の標準となっています。 プリプロセッサの主な利点の 1 ...