ホームページ > ウェブフロントエンド > jsチュートリアル > イベントのバブリングが不必要な問題を引き起こさないようにする方法

イベントのバブリングが不必要な問題を引き起こさないようにする方法

PHPz
リリース: 2024-01-12 16:41:06
オリジナル
766 人が閲覧しました

イベントのバブリングが不必要な問題を引き起こさないようにする方法

イベント バブリングによって引き起こされる不要な問題を回避するには、特定のコード例が必要です。

イベント バブリングとは、要素上のイベントがトリガーされると、隣接する要素上の同じイベントが発生することを意味します。親要素もトリガーされます。このイベント伝播メカニズムは、イベント ソースを正確にキャプチャできない、パフォーマンス上の問題を引き起こすなど、不要な問題を引き起こす可能性があります。このような問題を回避するために、イベントのバブリングを防ぐためのいくつかの対策を講じることができます。この記事では、いくつかの一般的な方法を紹介し、参考として対応するコード例を示します。

1. stopPropagation() メソッドを使用します

stopPropagation() メソッドは、イベントのバブリングが伝播し続けるのを防ぎ、現在の要素でのみイベントをトリガーし、同じ要素ではトリガーしないようにすることができます。他の親要素のイベント。イベント処理関数でこのメソッドを呼び出すだけです。

サンプル コードは次のとおりです。

<div id="parent">
  <div id="child">
    <button id="btn">点击触发事件</button>
  </div>
</div>

<script>
document.getElementById('btn').addEventListener('click', function(e) {
  console.log('子元素被点击');
  e.stopPropagation();
});

document.getElementById('child').addEventListener('click', function() {
  console.log('子元素的父元素被点击');
});

document.getElementById('parent').addEventListener('click', function() {
  console.log('父元素被点击');
});
</script>
ログイン後にコピー

上記のコードを実行した後、ボタンをクリックすると、子要素がクリックされたというメッセージのみがトリガーされますが、親要素がクリックされてもトリガーされません。

2. イベント委任を使用する

イベント委任とは、イベントを親要素にバインドし、event.target 属性を通じてイベント ソースを判断し、対応する操作を実行することを指します。このようにして、イベント処理関数を各子要素にバインドすることを回避し、コードの冗長性とメンテナンスの複雑さを軽減できます。

サンプル コードは次のとおりです。

<ul id="list">
  <li>选项1</li>
  <li>选项2</li>
  <li>选项3</li>
  <li>选项4</li>
</ul>

<script>
document.getElementById('list').addEventListener('click', function(event) {
  if (event.target.tagName === 'LI') {
    console.log(event.target.textContent);
  }
});
</script>
ログイン後にコピー

上記のコードを実行すると、クリック イベントを各オプションにバインドせずに、各オプションをクリックすると、対応するテキスト コンテンツが出力されます。

3. stopImmediatePropagation() メソッドを使用する

stopImmediatePropagation() メソッドは、イベントのバブリングを防ぐだけでなく、イベント処理関数のそれ以上の実行を防ぐことができるため、他の関連イベントの発生を防ぐことができます。引き起こされている。イベント処理関数でこのメソッドを呼び出すだけです。

サンプル コードは次のとおりです。

<div>
  <button id="btn1">按钮1</button>
  <button id="btn2">按钮2</button>
</div>

<script>
document.getElementById('btn1').addEventListener('click', function(e) {
  console.log('按钮1被点击');
  e.stopImmediatePropagation();
});

document.getElementById('btn1').addEventListener('click', function() {
  console.log('按钮1被点击,但此函数不会执行');
});

document.getElementById('btn2').addEventListener('click', function() {
  console.log('按钮2被点击');
});
</script>
ログイン後にコピー

上記のコードを実行した後、ボタン 1 がクリックされると、ボタン 1 がクリックされたというメッセージのみがトリガーされ、2 番目のバインド クリック イベントがトリガーされます。トリガーされません。

要約すると、stopPropagation() メソッド、イベント委任、stopImmediatePropagation() メソッドを使用することで、イベントのバブリングによって引き起こされる不要な問題を回避できます。これらのメソッドは、イベントの伝播を効果的に管理し、コードの可読性とパフォーマンスを向上させることができます。この記事で提供されているコード例が、読者の理解を深め、関連する知識を適用するのに役立つことを願っています。

以上がイベントのバブリングが不必要な問題を引き起こさないようにする方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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