ホームページ >ウェブフロントエンド >jsチュートリアル >JavaScript の一般的なイベント バブリング メカニズムをマスターする

JavaScript の一般的なイベント バブリング メカニズムをマスターする

王林
王林オリジナル
2024-02-19 16:43:05535ブラウズ

JavaScript の一般的なイベント バブリング メカニズムをマスターする

JavaScript における一般的なバブリング イベント: 一般的なイベントのバブリング特性を習得するには、特定のコード例が必要です

はじめに:
JavaScript では、イベント バブリングとはイベントは、最も深いネスト レベルの要素から外側の要素に、最も外側の親要素に到達するまで伝播します。一般的なバブリング イベントを理解し、習得することは、ユーザー インタラクションやイベント処理をより適切に処理するのに役立ちます。この記事では、一般的なバブリング イベントをいくつか紹介し、読者の理解を助ける具体的なコード例を示します。

1. クリック イベント (クリック):

クリック イベントは、最も一般的なバブリング イベントです。ユーザーがページ上の要素をクリックすると、その要素のクリック イベントがトリガーされ、最も外側の親要素のクリック イベントがトリガーされるまで、段階的に外側の要素に伝播されます。

HTML サンプル コード:

<div id="outer">
  <div id="inner">
    <button id="btn">点击我</button>
  </div>
</div>

JavaScript コード:

document.getElementById('outer').addEventListener('click', function() {
  console.log('outer clicked');
});

document.getElementById('inner').addEventListener('click', function() {
  console.log('inner clicked');
});

document.getElementById('btn').addEventListener('click', function() {
  console.log('button clicked');
});

ボタンをクリックすると、コンソールに次の結果が出力されます:

button clicked
inner clicked
outer clicked

2.マウス移動イベント (mousemove):

マウス移動イベントも一般的なバブリング イベントです。ユーザーがページ上でマウスを移動すると、マウス移動イベントが段階的に外側の要素に伝播されます。

HTML サンプル コード:

<div id="outer">
  <div id="inner">
    <button id="btn">移动鼠标</button>
  </div>
</div>

JavaScript コード:

document.getElementById('outer').addEventListener('mousemove', function() {
  console.log('outer mousemove');
});

document.getElementById('inner').addEventListener('mousemove', function() {
  console.log('inner mousemove');
});

document.getElementById('btn').addEventListener('mousemove', function() {
  console.log('button mousemove');
});

マウスをボタンの上に移動すると、コンソールに次の結果が出力されます:

button mousemove
inner mousemove
outer mousemove

3、キーボード押下イベント (キーダウン):

キーボード押下イベントは外側の要素にもバブルアップされます。ユーザーがページ上のキーボードのいずれかのキーを押すと、キーボード押下イベントが段階的に外側の要素に伝播されます。

HTML サンプル コード:

<div id="outer">
  <div id="inner">
    <input id="input" type="text" placeholder="按下键盘">
  </div>
</div>

JavaScript コード:

document.getElementById('outer').addEventListener('keydown', function() {
  console.log('outer keydown');
});

document.getElementById('inner').addEventListener('keydown', function() {
  console.log('inner keydown');
});

document.getElementById('input').addEventListener('keydown', function() {
  console.log('input keydown');
});

入力ボックスでキーボードを押すと、コンソールに次の結果が出力されます:

input keydown
inner keydown
outer keydown

結論:
一般的なバブリング イベントの上記の例を通じて、JavaScript でのイベント バブリングのアプリケーションを理解しました。イベント バブリングをマスターすると、ユーザー インタラクションとイベント処理をより適切に処理できるようになります。フォーカス イベントやフォーム イベントなど、一部のイベントはバブルしませんが、ほとんどの一般的な DOM イベントはバブルすることに注意してください。開発プロセスでは、ニーズに応じて処理に適切なイベント タイプを選択し、イベントのバブリング特性に応じて処理ロジックを調整する必要があります。この記事の紹介とサンプル コードを通じて、読者がバブリング イベントの概念をより深く理解し、それを独自のプロジェクトに適用できることを願っています。

以上がJavaScript の一般的なイベント バブリング メカニズムをマスターするの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。