JQuery の on() 関数はイベントを繰り返しバインドしますか?
JQuery は、フロントエンド開発で便利な DOM 操作とイベント処理を提供する人気のある JavaScript ライブラリであり、Web 開発では不可欠なツールの 1 つです。 JQuery を使用する場合、イベント バインディング関数 on() をよく使用しますが、多くの開発者は「JQuery の on() 関数はイベントを繰り返しバインドするのでしょうか?」という疑問に遭遇することがあります。
まず、on() 関数の定義と使用法を見てみましょう:
$(selector).on(event, childSelector, data, function(){...})
その中で、セレクターはイベントがバインドされる要素であり、イベントはバインドされる要素ですイベント タイプ、childSelector はイベント デリゲートの子要素セレクターを宣言します。data はイベント ハンドラーに渡されるデータ、function はバインドされたイベント ハンドラーです。
on() 関数の動作原理は次のとおりです。イベントがトリガーされると、セレクターによって一致した要素が、対応するイベント ハンドラーによって処理されます。 on() 関数は、選択した要素のイベント リスナー リストにイベント ハンドラーを追加します。
では、on() 関数を複数回使用して同じイベント タイプをバインドするとどうなるでしょうか?
実際には、on() 関数が呼び出されるたびに、同じイベント ハンドラーがすでにバインドされている場合でも、このイベント タイプのイベント ハンドラーがイベント リスナー リストに追加されます。これは、on メソッドを複数回使用して同じイベントをバインドすると、同じイベント ハンドラーがイベント リスナー リストに繰り返し追加されることを意味します。
たとえば、次のコードはクリック イベントを繰り返しバインドします:
$(selector).on('click', function(){...}); $(selector).on('click', function(){...}); $(selector).on('click', function(){...});
このようにして、要素がクリックされるたびに、JQuery はバインドの順序でイベント ハンドラーを 3 回実行します。 。
ただし、on() 関数を使用してイベント ハンドラーをバインドする場合は、再度 off() 関数を使用してイベント ハンドラーのバインドを解除し、再度 on() 関数を使用してイベント ハンドラーをバインドします。 、このイベント ハンドラーは 1 回だけ追加されます。なぜなら、off() 関数を使用してイベントのバインドを解除すると、JQuery はイベント リスナー リストからイベント ハンドラーを削除し、on() 関数を再度使用するときにそれを再追加するからです。
したがって、off() 関数を使用してイベントのバインドを解除することで、on() 関数によるイベントの繰り返しバインドの問題を回避できます。
$(selector).on('click', function(){ // code here; $(selector).off('click');//解绑click事件 $(selector).on('click', function(){ // do something }); });
上記のコードでは、イベント ハンドラーで off() 関数を使用して、クリック イベントのバインドを解除します。次に、新しいクリック イベントがイベント ハンドラーで再バインドされ、新しいイベント ハンドラーが追加されました。
もちろん、on() 関数がイベントを繰り返しバインドすることを避けるために、off() 関数を使用してイベントのバインドを解除することに加えて、イベントがイベント内にすでに存在するかどうかを判断することによって繰り返しバインドを防ぐこともできます。リスナーリスト。
if(!$(selector).data('hasBind')){ $(selector).data('hasBind', true).on('click', function(){ // do something }); }
上記のコードでは、data() メソッドを使用して要素に hasBind 属性を作成し、その初期値を false に設定します。そして、hasBind 属性の値を判定し、false であればイベントをバインドし、hasBind 属性の値を true に設定し、今後繰り返しバインドされないようにする。
要約すると、JQuery の on() メソッドはイベントを繰り返しバインドするため、off() 関数を使用してイベントのバインドを解除するか、イベントが既にイベント リスナー リストに存在するかどうかを判断して重複を防ぐ必要があります。バインディング。これにより、イベントをバインドする際の繰り返し実行の問題をより適切に回避し、フロントエンド開発の効率を向上させることができます。
以上がJQuery の on() 関数はイベントを繰り返しバインドしますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









この記事では、functionコンポーネントでのデータフェッチやDOM操作などの副作用を管理するためのフックであるReactの使用Effectについて説明します。メモリリークなどの問題を防ぐための使用、一般的な副作用、およびクリーンアップについて説明します。

怠zyな読み込みは、必要になるまでコンテンツの読み込みを遅延させ、初期負荷時間とサーバーの負荷を削減することにより、Webパフォーマンスとユーザーエクスペリエンスを改善します。

この記事では、Virtual DOMツリーを比較してDOMを効率的に更新するReactの調整アルゴリズムについて説明します。パフォーマンスの利点、最適化技術、ユーザーエクスペリエンスへの影響について説明します。

この記事では、JavaScriptのカレーについて説明します。これは、マルチアーグメント関数を単一argument関数シーケンスに変換する手法です。 Curryingの実装、部分的なアプリケーションなどの利点、実用的な用途、コード読み取りの強化を調査します

JavaScriptの高次関数は、抽象化、共通パターン、および最適化技術を通じて、コードの簡潔さ、再利用性、モジュール性、およびパフォーマンスを強化します。

この記事では、ReactのUseContextを説明しています。これにより、小道具掘削を避けることで国家管理を簡素化します。再レンダーの削減により、集中状態やパフォーマンスの改善などの利点について説明します。

記事では、Connect()、MapStateToprops、MapDispatchToprops、およびパフォーマンスへの影響を説明するReduxストアに反応コンポーネントをReduxストアに接続します。

記事では、PreventDefault()メソッドを使用して、イベントハンドラーのデフォルト動作の防止、ユーザーエクスペリエンスの強化などの利点、およびアクセシビリティの懸念などの潜在的な問題について説明します。
