バブリングとは何ですか?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 データベースをインストールしてデバッグする詳細な手順 [例]
導入: Nginx (エンジン エックスと同じ発音) は、BSD のようなプロトコルに基づいてリリー...
目次導入ミラーリポジトリログイン引く押す検索ローカル画像管理画像rmiタグ建てる歴史保存負荷輸入コン...
SELECT * FROM テーブル名制限m,n; SELECT * FROM テーブル LIMI...
1. CSSの記述形式1. インラインスタイルCSSコードを開始タグに直接記述することができます&l...
目次DockerファイルドキュメントJenkins の設定Spring Boot プロジェクトでは、...
「Tik Tok」も大人気で、ユーザー数は7億人と言われています。今日は、注目を集めるためにTikT...
導入: MySQL データベースの仕様に関しては、皆さんも何らかのドキュメントを読んだことがあると思...
1. IPアドレスを設定する前に、まずifconfigを使用してネットワークカード情報を表示し、ネッ...
mysql は期間内のすべての日付または月を取得します1: mysqlは期間内のすべての月を取得し...
1. MySQL インストール パッケージをダウンロードします(ここにはコツがあります。おそらく、こ...
Windows 2008 Serverのサブドメインを親ドメインに参加させると、「ドメインは既に存...
1. MySQL 5.7.11 zipインストールパッケージをダウンロードするこのマシンはwin7 ...
目次概要1. Refsオブジェクトの作成1.1 React.createRef() 1.2React...
目次1 配列のフラット化とは何ですか? 2 JS標準ライブラリの配列フラット化メソッド3 フラットメ...
次のように: -m, --memory メモリ制限。形式は数値と単位です。単位は b、k、m、g の...