ホームページ > ウェブフロントエンド > jsチュートリアル > クリック イベント バブリングの原理と Web 開発での使用方法を学びます。

クリック イベント バブリングの原理と Web 開発での使用方法を学びます。

王林
リリース: 2024-01-13 12:47:21
オリジナル
1224 人が閲覧しました

クリック イベント バブリングの原理と Web 開発での使用方法を学びます。

クリック イベント バブリングの原理と Web 開発におけるその応用を理解する

Web 開発では、ユーザーとの対話が頻繁に発生します。中でもイベントは、このインタラクティブな効果を実現するための重要な仕組みの一つです。これらのイベントの中で、クリック イベントが最も広く使用されています。クリック イベント バブリングの原理と Web 開発におけるその応用を理解することを学ぶと、イベント メカニズムをより適切に把握し、より豊かなユーザー インタラクション エクスペリエンスを実現できます。

1. クリック イベント バブリングの原理

要素に親要素があり、その親要素も同じ種類のイベントにバインドされている場合、要素上でイベントが発生すると、その後、イベントは子要素から最上位の親要素までバブルアップします。このプロセスはイベント バブリングと呼ばれます。

たとえば、次の HTML 構造を持つ Web ページがあります:

<div id="box">
  <button id="btn">点击</button>
</div>
ログイン後にコピー

クリック イベント リスナーがこのボタンにバインドされているとします:

document.getElementById("btn").addEventListener("click", function(){
  console.log("按钮被点击了");
});
ログイン後にコピー

When the button isクリックすると、コンソールに「ボタンがクリックされました」と出力されます。これは、ボタンのクリック イベントがリスナーをトリガーしたためです。

同じ型のイベントリスナーを親要素 div にバインドすると:

document.getElementById("box").addEventListener("click", function(){
  console.log("div被点击了");
});
ログイン後にコピー

このように、ボタンがクリックされたときに、「ボタンがクリックされました」という出力だけでなく、ただし、「div がクリックされました」というメッセージも出力されます。これは、ボタン上でクリック イベントがトリガーされた後、親要素 div までバブルアップし続けるためです。

2. クリックイベントバブリングの応用

  1. コードの保守性と拡張性の向上

クリックイベントバブリングにより、イベントをバインドできます。イベント リスナーを各子要素にバインドせずに、リスナーを親要素に追加します。これにより、コードの量が大幅に削減され、メンテナンスと拡張が容易になります。

たとえば、複数の li 要素を含む ul リストがあるとします。 li 要素をクリックすると背景色が変更されます。コードは次のように記述できます:

<ul id="list">
  <li>选项1</li>
  <li>选项2</li>
  <li>选项3</li>
</ul>
ログイン後にコピー
var lis = document.getElementById("list").getElementsByTagName("li");
for(var i=0; i<lis.length; i++){
  lis[i].addEventListener("click", function(){
    this.style.backgroundColor = "red";
  });
}
ログイン後にコピー

ただし、後で新しい li 要素を追加する必要がある場合は、JavaScript コード内で再度それを維持する必要があります。また、イベント バブリングを使用する場合は、イベント リスナーを ul 要素にバインドするだけで済みます:

document.getElementById("list").addEventListener("click", function(e){
  if(e.target.tagName.toLowerCase() === "li"){
    e.target.style.backgroundColor = "red";
  }
});
ログイン後にコピー

li 要素がいくつあっても、必要なリスナーは 1 つだけであり、イベント バブリング メカニズムを使用できます。親要素のイベントを確認し、イベント ソースに基づいてどの子要素がクリックされたかを判断します。

  1. イベント委任の実装

イベントバブリングを使用することで、イベント委任の機能を実現できます。イベント委任とは、要素のイベントをその親要素またはより上位の要素に処理のために引き渡すことを指します。これにより、リスナーの数が減り、動的バインディングが容易になります。

たとえば、表があり、マウスをセルの上に置くと、セルの背景色が変わるとします。コードは次のように記述できます:

<table id="table">
  <tr>
    <td>1</td>
    <td>2</td>
    <td>3</td>
  </tr>
  <tr>
    <td>4</td>
    <td>5</td>
    <td>6</td>
  </tr>
</table>
ログイン後にコピー
var tds = document.getElementById("table").getElementsByTagName("td");
for(var i=0; i<tds.length; i++){
  tds[i].addEventListener("mouseover", function(){
    this.style.backgroundColor = "yellow";
  });
  tds[i].addEventListener("mouseout", function(){
    this.style.backgroundColor = "white";
  });
}
ログイン後にコピー

ただし、後で新しいセルを追加する必要がある場合は、JavaScript コード内で再度セルを維持する必要があります。イベント バブリングを使用する場合、テーブル要素にイベント リスナーをバインドするだけで済みます。

document.getElementById("table").addEventListener("mouseover", function(e){
  if(e.target.tagName.toLowerCase() === "td"){
    e.target.style.backgroundColor = "yellow";
  }
});
document.getElementById("table").addEventListener("mouseout", function(e){
  if(e.target.tagName.toLowerCase() === "td"){
    e.target.style.backgroundColor = "white";
  }
});
ログイン後にコピー

イベント ソースを判断することで、リスナーを各セルにバインドすることを回避できます。これにより、リスナーの数が減り、動的バインディングが容易になります。

つまり、クリック イベント バブリングの原理と Web 開発におけるその応用を理解すると、コードの保守性とスケーラビリティを向上させることができ、同時にイベント委任の機能を実現することができます。同時に、イベント バブリングにより、ユーザー インタラクションをより適切に制御および処理することもできます。実際の Web 開発では、クリック イベント バブリングのメカニズムを深く理解し、柔軟に使用することで、開発効率とユーザー エクスペリエンスが大幅に向上します。

以上がクリック イベント バブリングの原理と Web 開発での使用方法を学びます。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート