JavaScript addEventListener()
仕様書を読んでもわかりにくい、addEventListener()の第3引数useCaptureの意味についてのメモ。
addEventListener()はIEでは未実装なので関係なし。
以下はFireFoxで確認。
useCaptureの意味
通常登録したイベントハンドラ(*1)はイベント伝搬のバブリングフェーズで呼ばれる。このため、DOM Treeの下の方のエレメントからイベントハンドラが順番に呼ばれる。useCaptureをtrueにしてイベントハンドラを登録すると、キャプチャフェーズでイベントハンドラが呼ばれるようになる。このため、その他のイベントハンドラに先だって呼び出されるようになる。
(*1) 以下のものが含まれる。
- DOMエレメントのプロパティに設定したイベントハンドラ(element.onmousedown = handler)
- HTMLタグに埋め込んだイベントハンドラ(<div onmousedown='alert("xxxx");'>)
- 'useCapture = false'でaddEventListenerされたイベントハンドラ
以下に例を示す。図1に示すようなオブジェクトがあり、緑領域、青領域、テキスト領域にそれぞれonmousedownイベントハンドラが設定してあったとする。
図1 HTMLオブジェクト例
この場合、DOM Treeは図2のようになっており、「text」部分をクリックするとイベントハンドラはバブリングフェーズで呼び出されるので「テキスト領域 → 青領域 → 緑領域」の順番にイベントハンドラが呼び出される。
ここで、緑領域のイベントハンドラをaddEventListener()で'useCapture = true'にして登録すると、緑領域のイベントハンドラはキャプチャフェーズで呼び出されるようになり、「緑領域 → テキスト領域 → 青領域」の順番で呼び出されることになる。
実際に試す場合はこちらから。
図2 イベントの伝搬とハンドラの呼び出し
関連ドキュメント
DOM仕様書
http://www.w3.org/TR/DOM-Level-2-Events/events.html
イベントの伝搬については以下が参考になる。
http://www-06.ibm.com/jp/developerworks/xml/050107/j_x-events.html