「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > jQuery を使用して動的に追加された HTML 要素に「onclick」イベントをバインドする方法

jQuery を使用して動的に追加された HTML 要素に「onclick」イベントをバインドする方法

2024 年 11 月 9 日に公開
ブラウズ:186

How to Bind 'onclick' Events to Dynamically Added HTML Elements with jQuery?

jQuery を使用した動的イベント バインディング: 'onclick' 問題に対処する

フロントエンド開発の領域では、動的にイベントを追加するのが一般的です。 HTML 要素をページに追加します。ただし、これらの新しく追加された要素にイベントをバインドするのは難しい場合があります。従来のイベント バインド方法が期待どおりに機能しない可能性があるためです。

問題: ライブ イベントと委任されたイベント

動的に追加された要素を扱う場合、従来はライブ イベント バインディング (bind()、live()、delegate() などのメソッド) が主なソリューションでした。ただし、これらのメソッドはパフォーマンス上の理由から jQuery では非推奨になりました。

代わりに、イベントが静的要素 (多くの場合ドキュメント オブジェクト) にバインドされ、ハンドラーがそれに基づいて呼び出される委任されたイベント バインディングを使用する必要があります。

解決策: on() メソッドを使用する

onclick イベントをバインドするには委任されたイベント バインディングを使用して要素を動的に追加する場合は、jQuery on() メソッドを使用する必要があります。このメソッドは 3 つのパラメータを取ります:

  1. イベント タイプ (例: 「クリック」)
  2. イベントを添付する要素をターゲットとするセレクター
  3. イベントハンドラfunction

例:

$(document).on('click', '.my-dynamic-element', function() {
  // Code to execute when the element is clicked
});

動的に追加された複数の要素へのバインディング

複数の要素が動的に追加される場合、on( のセレクターとして共通のクラスまたは属性を使用することをお勧めします。 ) 方法。これにより、指定されたセレクターを持つすべての要素が一貫して処理されるようになります。

非推奨のメソッド

次のメソッドは非推奨であり、イベントには使用しないでください。 binding:

  • bind()
  • live()
  • delegate()

上記の on() メソッドの使用jQuery の最新バージョンとの互換性を確保し、動的に追加された要素に対する効率的なイベント処理を提供します。

最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3