JavaScriptでのバブリングとキャプチャリングの理解と使用方法について


JavaScriptにおいて、イベントのバブリングとキャプチャリングは重要な概念です。これらはイベントがDOMツリー内で伝播する方法を制御するために使用されます。以下では、バブリングとキャプチャリングの仕組みと、それらを活用する方法について説明します。

  1. バブリング: バブリングは、イベントが発生した要素から始まり、親要素へと伝播していくプロセスです。つまり、子要素から親要素へと順番にイベントが伝わっていくということです。通常、イベントリスナーを親要素に追加すると、子要素で発生したイベントもキャプチャされます。

以下のコード例を参考にしてみましょう。

// HTML
<div id="parent">
  <div id="child">
    Click me!
  </div>
</div>
// JavaScript
const parent = document.getElementById('parent');
const child = document.getElementById('child');
parent.addEventListener('click', function(event) {
  console.log('Parent clicked!');
});
child.addEventListener('click', function(event) {
  console.log('Child clicked!');
});

上記のコードでは、子要素のクリックイベントが発生すると、親要素のイベントリスナーも実行されます。つまり、コンソールには以下のように表示されます。

Child clicked!
Parent clicked!
  1. キャプチャリング: キャプチャリングは、バブリングとは逆の順序でイベントが伝播するプロセスです。イベントはルート要素から始まり、子要素へと伝播していきます。キャプチャリングフェーズでは、イベントリスナーが子要素から順番に実行されます。

以下のコード例を見てみましょう。

// HTML
<div id="parent">
  <div id="child">
    Click me!
  </div>
</div>
// JavaScript
const parent = document.getElementById('parent');
const child = document.getElementById('child');
parent.addEventListener('click', function(event) {
  console.log('Parent clicked!');
}, true); // 第3引数をtrueにすることでキャプチャリングを有効にします
child.addEventListener('click', function(event) {
  console.log('Child clicked!');
}, true); // 第3引数をtrueにすることでキャプチャリングを有効にします

上記のコードでは、親要素のクリックイベントが発生すると、子要素のイベントリスナーも実行されます。つまり、コンソールには以下のように表示されます。

Parent clicked!
Child clicked!

以上のように、バブリングとキャプチャリングを活用することで、イベントの伝播を制御することができます。これは、特定の要素に対してイベントが発生した場合に、それに応じた処理を行いたい場合に役立ちます。

このように、JavaScriptにおけるバブリングとキャプチャリングの理解と使用方法を説明しました。これらの概念を適切に活用することで、より柔軟なイベント制御が可能となります。