{category}

JavaScript - イベントオブジェクトとプロパティ

event.stopPropagation()

イベントストッププロパゲーション(イベント

意味 イベント伝播の停止


event.stopPropagation()とは?

イベントの伝播を停止するメソッドです。これにより、親や子のイベントハンドラが実行されなくなります。

event.stopPropagation()の具体的な使い方

イベントの伝播を停止する例

<div id="outer" style="padding: 20px; background-color: #f0f0f0;">
  外側の要素
  <div id="inner" style="padding: 20px; background-color: #d0d0d0;">
    内側の要素
    <button id="btn">クリックしてください</button>
  </div>
</div>

<script>
const outer = document.getElementById('outer');
const inner = document.getElementById('inner');
const btn = document.getElementById('btn');

outer.addEventListener('click', () => {
  console.log('外側の要素がクリックされました');
});

inner.addEventListener('click', () => {
  console.log('内側の要素がクリックされました');
});

btn.addEventListener('click', (event) => {
  event.stopPropagation();
  console.log('ボタンがクリックされました(伝播停止)');
});
</script>

この例では、ボタンをクリックするとevent.stopPropagation()が呼び出され、イベントの伝播が停止します。その結果、ボタンのクリックイベントだけが処理され、内側や外側の要素のクリックイベントは発火しません。ボタン以外の部分をクリックすると、イベントが通常通り伝播することを確認できます。

event.stopPropagation()に関するよくある質問

Q. stopPropagation()の目的は?
A. stopPropagation()メソッドの主な目的は、イベントの伝播(バブリングやキャプチャリング)を停止することです。これにより、親要素や子要素のイベントハンドラが呼び出されるのを防ぐことができます。
Q. いつ使うべきですか?
A. 特定の要素でのみイベントを処理し、親要素や子要素でのイベント処理を避けたい場合に使用します。例えば、モーダルウィンドウ内のクリックイベントが背景に伝播するのを防ぐ場合などに有用です。
Q. preventDefault()との違いは?
A. stopPropagation()はイベントの伝播を停止しますが、preventDefault()はデフォルトのブラウザ動作を阻止します。例えば、リンクのクリックイベントでpreventDefault()を使用すると、ページ遷移が発生しなくなります。

event.stopPropagation()が学べる書籍の紹介

「プログラミング単語帳」を使って、プログラミングの単語を英単語のように学習してみませんか?
プログラミング単語帳には、JavaScriptのevent.stopPropagation()やclick、event.bubbles、input、などのような実務でよく使われる単語が数百以上収録されています。
この書籍には、プログラミングの単語の意味や読み方、単語の使い方がわかる例文などが掲載されており、いつでもどこでもプログラミングの学習ができます。

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

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」カテゴリーが追加されましました!


関連するそのほかの単語

click

クリックイベント

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

event.bubbles

イベントが伝播可能か

種類: イベントオブジェクトとプロパティ

input

フォーム要素に入力があるたびのイベント。

種類: フォームイベント

querySelectorAll()

複数要素を取得

種類: DOMの選択(1)

Error

基本のエラーオブジェクト

種類: エラーオブジェクト