ホームページ >ウェブフロントエンド >jsチュートリアル >JS バブリング イベント解析ガイド: 初心者必読の資料

JS バブリング イベント解析ガイド: 初心者必読の資料

王林
王林オリジナル
2024-01-13 10:21:061337ブラウズ

JS バブリング イベント解析ガイド: 初心者必読の資料

初心者必読: JS バブリング イベントとアプリケーション シナリオの分析の概要

はじめに:
Web 開発において、JavaScript (JS) は非常に重要です。重要なプログラミング言語。 JS の基本的な構文と操作をマスターした後、JS のイベント メカニズムを理解することが、能力をさらに向上させる鍵となります。中でもバブリングイベントはJSイベント機構における重要な概念です。この記事では、JS バブリング イベントの概念、原則、実際の応用シナリオを詳細に紹介し、初心者がイベントをよりよく理解して習得できるように、具体的なコード例を示します。

1. 概念:
バブリング イベントとは、要素がイベントをトリガーすると、そのイベントが最も外側の祖先要素までトリガーされるまで、親要素で順番にトリガーされることを意味します。この過程は泡が底から上がってくるようなものなので、バブリングイベントと呼ばれます。

2. 原則:
バブリング イベントの原則は、DOM ツリー構造、つまりドキュメント オブジェクト モデルに基づいています。 Web ページでは、すべての要素 (HTML タグや JS によって作成された要素を含む) が DOM ツリーのノードと見なされます。要素でイベントが発生すると、JS エンジンは DOM ツリーの構造に従って同じタイプのイベントを順番にトリガーします。つまり、最も外側の祖先要素まで親要素で同じイベントをトリガーします。

3. コード例 1: バブリング イベントの基本的な使用法
以下は、バブリング イベントの基本的な使用法を示す単純な HTML コードの一部です:

<!DOCTYPE html>
<html>
<head>
  <title>冒泡事件示例</title>
</head>
<body>
  <div id="outer">
    <div id="inner">
      <button id="btn">点击触发冒泡事件</button>
    </div>
  </div>

  <script>
    // 选择DOM元素
    const outer = document.querySelector('#outer');
    const inner = document.querySelector('#inner');
    const btn = document.querySelector('#btn');

    // 添加冒泡事件监听
    outer.addEventListener('click', function() {
      console.log('父级元素outer被点击');
    });

    inner.addEventListener('click', function() {
      console.log('子级元素inner被点击');
    });

    btn.addEventListener('click', function() {
      console.log('按钮被点击');
    });
  </script>
</body>
</html>

上記のコードでは、親要素の外側、子要素の内側、ボタン要素 btn にクリック イベント リスナーを追加しました。ボタンをクリックすると、次の情報がコンソールに出力されます。

按钮被点击
子级元素inner被点击
父级元素outer被点击

これは、ボタン要素のクリック イベントが内側の子要素と外側の親要素にバブルし、対応するイベントをトリガーするためです。コールバック関数。

4. コード例 2: バブリング イベントのアプリケーション シナリオ
バブリング イベントのアプリケーション シナリオは非常に幅広いです。以下では、バブリング イベントの実際的な応用例を示すために、ショッピング カートのアイテム削除機能を例に挙げます。

<!DOCTYPE html>
<html>
<head>
  <title>冒泡事件应用场景示例</title>
  <style>
    .item {
      margin-bottom: 10px;
      padding: 5px;
      border: 1px solid #ccc;
    }
    .delete-btn {
      float: right;
      cursor: pointer;
    }
  </style>
</head>
<body>
  <div id="cart">
    <div class="item">
      商品1
      <span class="delete-btn">删除</span>
    </div>
    <div class="item">
      商品2
      <span class="delete-btn">删除</span>
    </div>
    <div class="item">
      商品3
      <span class="delete-btn">删除</span>
    </div>
  </div>

  <script>
    // 选择DOM元素
    const cart = document.querySelector('#cart');

    // 添加冒泡事件监听
    cart.addEventListener('click', function(event) {
      const target = event.target;
      if (target.classList.contains('delete-btn')) {
        const item = target.parentNode;
        item.remove();
        console.log('删除成功');
      }
    });
  </script>
</body>
</html>

上記のコードでは、各製品要素の削除ボタンのクリック イベント リスナーを追加しました。削除ボタンをクリックすると、「削除に成功しました」というメッセージがコンソールに出力され、対応する製品要素がショッピング カートから削除されます。これは、削除ボタンがクリックされると、バブリングイベントにより親要素のカート上のクリックイベントリスニング機能がトリガーされ、クリックされた対象要素が削除ボタンであるかどうかを判定することで、特定の削除機能を実装することができるためです。

概要:
バブル イベントは、JS イベント メカニズムにおける重要な概念であり、Web 開発において無視できない部分です。この記事では、バブリング イベントの概念、原理、実際の応用シナリオを詳しく紹介しているので、初心者はすでにバブリング イベントについて予備的な理解と習得ができていると思います。この記事が、初心者がバブリング イベントをよりよく理解して適用し、JS プログラミング スキルを向上させるのに役立つことを願っています。

以上がJS バブリング イベント解析ガイド: 初心者必読の資料の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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