{category}

JavaScript - イベントの伝播

キャプチャリングフェーズ

イベント

意味 イベント伝播の初期


キャプチャリングフェーズとは?

イベント伝播の最初の段階。イベントは最上位の親要素から対象の要素まで伝播します。

キャプチャリングフェーズの具体的な使い方

キャプチャリングフェーズでのイベントリスナー設定例

<div id="parent" style="padding: 20px; background-color: #f0f0f0;">
  親要素
  <div id="child" style="padding: 20px; background-color: #d0d0d0;">
    子要素
  </div>
</div>
<div id="log"></div>

<script>
const parent = document.getElementById('parent');
const child = document.getElementById('child');
const log = document.getElementById('log');

parent.addEventListener('click', function(e) {
  log.innerHTML += '親要素: キャプチャリングフェーズ<br>';
}, true);

child.addEventListener('click', function(e) {
  log.innerHTML += '子要素: ターゲットフェーズ<br>';
});

parent.addEventListener('click', function(e) {
  log.innerHTML += '親要素: バブリングフェーズ<br>';
});
</script>

親要素と子要素にイベントリスナーを設定し、キャプチャリングフェーズ、ターゲットフェーズ、バブリングフェーズの順序を確認します。

キャプチャリングフェーズに関するよくある質問

Q. キャプチャリングフェーズとは?
A. キャプチャリングフェーズは、イベントが最上位の親要素から対象の要素まで伝播する過程です。イベントの伝播の最初の段階となります。
Q. キャプチャリングを使う場面は?
A. 特定の親要素でイベントを先に処理したい場合や、イベントの伝播を制御したい場合に使用します。例えば、子要素のイベントを親要素で先にキャッチして処理したい時などに有用です。
Q. どう設定する?
A. addEventListener メソッドの第3引数に true を指定することで、キャプチャリングフェーズでイベントリスナーを設定できます。例:element.addEventListener('click', handler, true);

キャプチャリングフェーズが学べる書籍の紹介

「プログラミング単語帳」を使って、プログラミングの単語を英単語のように学習してみませんか?
プログラミング単語帳には、JavaScriptのキャプチャリングフェーズやcontextmenu、touchstart、mousemove、などのような実務でよく使われる単語が数百以上収録されています。
この書籍には、プログラミングの単語の意味や読み方、単語の使い方がわかる例文などが掲載されており、いつでもどこでもプログラミングの学習ができます。

よく使われる単語にだけ絞って学習することができるので、効率的にプログラミングが学習できます。

1日5分の暗記でプログラミンが身に付く!プログラミング単語帳 公式ストアで発売中!

HTML編、CSS編、JavaScript編、PHP編、Ruby編、その他単語編の6シリーズ分が公式ストアにて販売中です。気になった方はぜひ購入してみてください。


JavaScriptを学べる「プログラミング単語帳」アプリ

プログラミング単語帳がアプリになりました!JavaScriptはもちろん、10種類のプログラミング言語の中から、よく使われる単語をスマホで学習できます。

収録単語は2,000単語以上!
現在は、HTML、CSS、JavaScirpt、PHP、Laravel、Ruby、Python、MySQL、Linux、など10カテゴリーの単語帳が1つのアプリに収録されています。

いつでも、どこでも、隙間時間を有効活用して、プログラミングを効率的に学べるので、ぜひダウンロードしてみてください。

2024年7月アップデート情報:「Laravel」カテゴリーが追加されましました!

2024年8月アップデート情報:「MySQL」「Linux」カテゴリーが追加されましました!


関連するそのほかの単語

contextmenu

要素上で右クリックすると発生する。

種類: ユーザーインタラクションイベント

touchstart

要素をタッチしたときに発生する。

種類: ユーザーインタラクションイベント

mousemove

マウス移動イベント

種類: ユーザーインタラクションイベント

Promise

非同期処理の表現

種類: Promise

array.join()

要素を文字列に

種類: Array