[解決済み】addEventListenerのuseCaptureパラメータが理解できない。
2022-03-27 05:36:45
質問
の記事を読みました。
https://developer.mozilla.org/en/DOM/element.addEventListener
が、理解できない。
useCapture
属性があります。定義があります。
useCapture が true の場合、ユーザがキャプチャを開始したいことを示します。キャプチャを開始すると、指定されたタイプのすべてのイベントは、DOM ツリーでその下にある任意の EventTargets にディスパッチされる前に、登録されたリスナーにディスパッチされるようになります。ツリーを上方に流れるイベントは、キャプチャを使用するように指定されたリスナーをトリガしません。
このコードでは、親イベントが子イベントより先にトリガーされるため、このコードが理解できません。 Documentオブジェクトはusecaptureをtrueに設定し、子divはusecaptureをfalseに設定し、document usecaptureに従いました。
function load() {
document.addEventListener("click", function() {
alert("parent event");
}, true);
document.getElementById("div1").addEventListener("click", function() {
alert("child event");
}, false);
}
<body onload="load()">
<div id="div1">click me</div>
</body>
解決方法は?
イベントは2つの場面で起動することができます。開始時 ("capture") と終了時 ("bubble") です。 イベントは、定義された順番に実行されます。例えば、4つのイベントリスナーを定義したとする。
window.addEventListener("click", function(){console.log(1)}, false);
window.addEventListener("click", function(){console.log(2)}, true);
window.addEventListener("click", function(){console.log(3)}, false);
window.addEventListener("click", function(){console.log(4)}, true);
ログメッセージはこの順番で表示されます。
-
2
(最初に定義されcapture=true
) -
4
(2番目の定義はcapture=true
) -
1
(最初に定義されたイベントをcapture=false
) -
3
(2つ目の定義されたイベントであるcapture=false
)
関連
-
[解決済み】TypeError: $(...).DataTable は関数ではありません。
-
[解決済み】最大呼び出しスタックサイズ超過エラーとその修正方法とは?
-
[解決済み】JavaScript "Uncaught TypeError: object is not a function" 連想性の質問
-
[解決済み】Javascript - ERR_CONTENT_LENGTH_MISMATCH
-
[解決済み】SyntaxError: JSON の位置 1 に予期しないトークン o があります。
-
[解決済み】Redux TypeError: 未定義のプロパティ 'apply' を読み取れない
-
[解決済み】Babel NodeJS ES6: SyntaxError: 予期しないトークンのエクスポート
-
[解決済み] addEventListenerとonclickの比較
-
[解決済み】JavaScriptの関数にデフォルトのパラメータ値を設定する
-
[解決済み】absoluteの親divの子要素をホバーしたときのonmouseoutをjQueryなしで防止する。
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】パッシブイベントリスナー内部でpreventDefaultができない
-
[解決済み] エラー。モジュールhtmlが見つからない
-
[解決済み】JavaScript ランタイムエラー:'$'が未定義です。
-
[解決済み】React.jsの配列の子要素のユニークキーを理解する
-
[解決済み】npm install --legacy-peer-deps は具体的に何をするのですか?どんなときに推奨されるのか/どんな使用例が考えられるのか?
-
[解決済み] ローカルファイルを開くことができません - Chrome: ローカルリソースのロードが許可されていません
-
[解決済み】DOMException: サポートされているソースが見つからなかったため、読み込みに失敗しました。
-
[解決済み】Vueのテンプレートまたはレンダー関数が定義されていない 私はどちらも使っていないのですが?
-
[解決済み】HTMLの最初の行に予期しないトークン<がある。
-
[解決済み] addEventListenerとonclickの比較