JavaScript イベント学習 第 8 章 イベントのシーケンス_JavaScript スキル
基本的な質問は簡単です。 1 つの要素が別の要素内に含まれているとします。
-------- --- -----------------------
|
| ---- -------- |要素 2 | - |
----------------------------------
これら 2 つの要素にはすべて onclick イベント ハンドラーがあります。ユーザーが要素 2 をクリックすると、要素 2 と要素 1 の両方でクリック イベントがトリガーされます。しかし、最初に起こったのはどの出来事でしょうか?どのイベント ハンドラーが最初に実行されますか?言い換えれば、イベントの順序は何ですか?
2 つのモード
Netscape と Microsoft の両方が、過去の悪い時代に独自の決定を下したことは疑いの余地がありません。
Netscape は、element1 が最初に発生したと述べました。これをイベントキャプチャと呼びます。
Microsoft は要素 2 が最初に発生したと考えています。これをイベントバブリングと呼びます。
これら 2 つのイベントの順序はまったく逆です。 IE はイベント バブリングのみをサポートします。 Mozilla、Opera 7、Konqueror は両方をサポートしています。以前の Opear ブラウザと iCab ブラウザはどちらもサポートしていません。
イベントキャプチャ
イベントキャプチャを使用する場合
| |
| |------| ------ ------------------ |
| イベントのキャプチャ | ------ ----------------
要素 1 のイベント ハンドラーが最初に実行され、次に要素 2 が実行されます。
イベントバブリング
ただし、イベントバブリングを使用する場合は
コードをコピーします
要素 2 のイベント ハンドラが最初に実行され、要素 1 のイベント ハンドラが後で実行されます。 。
W3C モード
W3C はこの戦争で重力を維持することを決定しました。 W3C イベント モデルでは、発生したイベントはターゲット要素に到達するまでまずキャプチャされ、その後バブルアップされます。
コードは次のとおりです:
デザイナーは、イベント ハンドラーをキャプチャ ステージまたはバブリング ステージに登録することを選択できます。これは、以前のアドバンスト モードで導入された addEventListener() メソッドを通じて実現できます。最後のパラメータが true の場合はイベント キャプチャに設定され、false の場合はイベント バブリングに設定されます。
次のように書くとします。
element1.addEventListener('click',doSomething2,true)
element2.addEventListener('click',doSomething,false)
ユーザーが element2 をクリックした場合次のことが起こります:
、キャプチャフェーズでクリックイベントが発生します。 element2の親要素にonclickイベントハンドラがあればそれが実行されるようです。
、イベントは element1 で doSomething2() を見つけ、実行されます。
では、イベントはターゲット自体に渡され、他のキャプチャ フェーズ プログラムはありません。イベントはバブリングフェーズに入り、doSomething() が実行されます。これは、バブリングフェーズで element2 によって登録されたイベント ハンドラーです。
の場合、イベントは上方に渡され、バブリング段階で親要素がイベント ハンドラーを設定しているかどうかがチェックされます。ここには誰もいないので、何も起こりません。
逆:
element1.addEventListener('click',doSomething2,false)
element2.addEventListener('click',doSomething,false)
ユーザーが element2 をクリックした場合発生:
、キャプチャフェーズでイベントクリックが発生します。このイベントは、キャプチャ フェーズ中に element2 の親要素にイベント ハンドラーが登録されているかどうかを確認しますが、ここでは当てはまりません。
、イベントはターゲット自体に渡されます。次に、バブリングフェーズが開始され、dosomething() が実行されます。これは、element2 のバブリングフェーズに登録されたイベント ハンドラーです。
では、イベントは上向きに渡され続け、バブリング段階で親要素がイベント ハンドラーを登録したかどうかを確認します。
、イベントが element1 を見つけた後、doSomething2() が実行されました。
レガシー モードでの互換性
W3C DOM をサポートするブラウザの場合、レガシー イベント登録
element1.onclick = doSomething2;
はバブリング ステージで登録されたとみなされます。
イベント バブリングの使用
イベントのキャプチャやバブリングを認識しているデザイナーはほとんどいません。今日の Web ページ作成の世界では、バブリング イベントを一連のイベント ハンドラーで処理する必要はないようです。また、クリック後に発生する一連のイベントによってユーザーが混乱する可能性があるため、通常はイベント ハンドラー コードをある程度独立させておく必要があります。ユーザーが 1 つの要素をクリックすると何かが起こり、別の要素をクリックすると別のことが起こります。
もちろん、これは将来変更される可能性があります。モデルの前方互換性を維持することが最善です。しかし、現在最も実用的なイベント キャプチャとバブリングは、デフォルト関数の登録です。
それは常に発生します
最初に理解する必要があるのは、イベントのキャプチャまたはバブリングは常に発生するということです。ページ全体に onclick イベントを定義する場合:
document.onclick = doSomething;
if (document.captureEvents) document.captureEvents(Event.CLICK);
任意の要素のクリック時間がページに表示されます。このイベント ハンドラーを開始します。先行するイベント ハンドラーが明示的にバブリングを防止する場合にのみ、バブリングはページ全体に渡されません。
を使用 ドキュメント全体で各イベントが停止するため、デフォルトのイベントハンドラーが可能になります。次のようなページがあるとします。
---- --------------------------------
| ドキュメント
| ---- ------- ------------ |
| ---- ------------
---------------------- ------- -----
element1.onclick = doSomething;
element2.onclick = doSomething;
ユーザーが element1 または element2 をクリックすると、doSomething() が実行されます。必要に応じて、ここで彼の拡散を止めることもできます。そうでない場合は、defaultFunction() が実行されます。ユーザーが他の場所をクリックした場合も、defaultFunction() が実行されます。場合によってはこれが役立つこともあります。
ドラッグコードを記述する際には、グローバルイベントハンドラーの設定が必要です。通常、レイヤー上の Mousedow イベントはこのレイヤーを選択し、mousemove イベントに応答します。通常、マウスダウンはブラウザのバグを避けるためにこのレベルで登録されますが、他のイベント ハンドラーはドキュメント全体である必要があります。
ブラウザ ロジックの第一法則を思い出してください。ほとんど準備ができていないときに、何でも起こります。発生する可能性があるのは、ユーザーのマウスが激しく動き、コードが追いつかず、マウスがこのレイヤーに存在しなくなることです。
onmousemove イベント ハンドラーがレイヤーに登録されている場合、レイヤーがマウスの動きに応答しなくなると、ユーザーは間違いなく混乱します。
onmouseup イベント ハンドラーが特定のページに登録されている場合、ユーザーがマウスを放したときにプログラムはレイヤーをキャプチャせず、レイヤーはマウスとともに移動したままになります。
グローバル イベント ハンドラーの実行が保証されているため、この場合はイベント バブリングが重要です。
オフにしてください
ただし、通常は、関連するキャプチャとバブリングをすべてオフにする必要があります。さらに、ドキュメント構造が非常に複雑である場合 (多数の複雑なテーブルなど)、システム リソースを節約するためにバブリングをオフにする必要もあります。それ以外の場合、ブラウザーは親要素を 1 つずつチェックして、イベント ハンドラーがあるかどうかを確認する必要があります。存在しないかもしれませんが、探すのはやはり時間の無駄です。
Microsoft モードでは、イベントの cancelBubble プロパティを true に設定する必要があります。
window.event.cancelBubble = true
W3C モードでは、stopPropagation() メソッドを呼び出す必要があります。
e.stopPropagation()
これにより、このイベントのバブリングフェーズが停止します。イベントの攻略極限を防ぐことは基本的に不可能です。理由も知りたいです。
完全なクロスブラウザ コードは次のとおりです:
function doSomething(e)
{
if (!e) var e = window.event;
e.cancelBubble = true; ();
}
currentTarget
前に述べたように、イベントにはターゲットが含まれるか、srcElement にはイベントが発生した要素への参照が含まれます。この場合、ユーザーがクリックしたため、それは element2 です。
このターゲットはキャプチャ中およびバブリング中は変化しないことを理解することが重要です。
ただし、次のイベント ハンドラーを登録するとします。
element1.onclick = doSomething; 🎜>element2.onclick = doSomething;
ユーザーが element2 をクリックすると、doSomething() が 2 回実行されます。では、どの HTML 要素がこのイベントを処理するのかをどのようにして知ることができるのでしょうか? target/scrElement は答えを与えることができません。イベントの最初から element2 を指しています。
この問題を解決するために、W3C は currentTarget 属性を追加しました。これには、処理されるイベントの HTML 要素への参照が含まれています。これは、必要なものです。残念ながら、Microsoft モードには同様のプロパティがありません。
このキーワードも使用できます。この例では、currentTarget で始まる、処理中のイベントの HTML 要素を指します。
Microsoft モデルの問題
しかし、Microsoft のイベント登録モデルを使用する場合、this キーワードは HTML 要素にのみ適用されるわけではありません。その場合、 currentTarget のようなプロパティはありません。つまり、次のようにすると、
element1.attachEvent('onclick',doSomething)
element2.attachEvent('onclick',doSomething)
は実行されません。どの HTML 要素がイベントを処理しているかを知ることができます。これは Microsoft のイベント登録モデルの最も深刻な問題であるため、たとえ IE/win でのみ動作するプログラムであっても、このモデルは絶対に使用しないでください。
Microsoft が currentTarget のようなプロパティをすぐに追加することを願っていますか、それとも標準に従っていますか?私たちは早急にデザインを必要としています。
続き
学習を続けたい場合は、次の章をお読みください。
元のアドレス: http://www.quirksmode.org/js/events_order.html
私のツイッター: @rehawk

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

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

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

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

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

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

ホットトピック











PHP8.0 のイベント処理ライブラリ: Event インターネットの継続的な発展に伴い、PHP は人気のバックエンド プログラミング言語として、さまざまな Web アプリケーションの開発に広く使用されています。このプロセスでは、イベント駆動のメカニズムが非常に重要な部分になっています。 PHP8.0 のイベント処理ライブラリ Event は、より効率的で柔軟なイベント処理メソッドを提供します。イベント処理とは何ですか? イベント処理は、Web アプリケーションの開発において非常に重要な概念です。イベントは任意の種類のユーザー行にすることができます

Steam のサマー セールは、これまでいくつかの最高のゲームの割引を主催してきましたが、今年は Valve によるさらなるホームランが積み重なっているようです。 Steam サマーセールの割引ゲームの一部を紹介するトレーラー (以下をご覧ください) がリリースされました。

Pygame のイベント モジュール Event (Event) は Pygame の重要なモジュールの 1 つで、一般的に使用されるマウス クリック、キーボード タップ、ゲーム ウィンドウの移動、ウィンドウのサイズ変更、特定のプロットのトリガー、終了など、ゲーム プログラム全体を構築する核心です。 . ゲームなど、これらは「イベント」とみなすことができます。イベントタイプ Pygame は、イベントを処理するために特別に使用される構造、つまりイベントキューを定義します。この構造は、キューの「早い者勝ち」の基本原則に従います。イベントキューを通じて、ユーザーの操作を順序立てて一度に処理できます。 -by-one方式(トリガーイベント)。次の表は、Pygame で一般的に使用されるゲーム イベントのリストです。 名前 説明 QUIT ユーザーがウィンドウの閉じるボタンを押した ATIVEEVENTPy

window.outerWidth イベントと window.outerHeight イベントを使用して、ブラウザのサイズが変更されたときの JavaScript のウィンドウ サイズを取得します。例 次のコードを実行して、イベントを使用してブラウザのウィンドウ サイズを確認してみることができます -<!DOCTYPEhtml><html> <head> <script>&am

Steam のサマー セールは、これまでいくつかの最高のゲームの割引を主催してきましたが、今年は Valve によるさらなるホームランが積み重なっているようです。 Steam サマーセールの割引ゲームの一部を紹介するトレーラー (以下をご覧ください) がリリースされました。

当初、テスラは以前にリークされたロボタクシーを今年8月に発表すると予想されていたが、最高経営責任者(CEO)のイーロン・マスクは、ロボタクシーの前面の美的変更と直前の準備に追加の時間が必要であることを理由にイベントを延期した。

当初、テスラは以前にリークされたロボタクシーを今年8月に発表すると予想されていたが、最高経営責任者(CEO)のイーロン・マスクは、ロボタクシーの前面の美的変更と直前の準備に追加の時間が必要であることを理由にイベントを延期した。

イベントを最初にキャプチャする必要がありますか、それとも最初にバブルする必要がありますか?イベント トリガー シーケンスの謎を解く イベント処理は Web 開発の非常に重要な部分であり、イベント トリガー シーケンスは謎の 1 つです。 HTML では、通常、イベントは「キャプチャ」または「バブリング」によって伝播されます。どちらを先にキャプチャすべきか、それとも最初にバブルすべきでしょうか?これは非常に紛らわしい質問です。この質問に答える前に、まずイベントの「キャプチャ」メカニズムと「バブル」メカニズムを理解しましょう。イベントのキャプチャとは、最上位の要素からターゲット ノードにイベントをレイヤーごとに渡し、イベントがバブルアップすることを指します。
