Bind で追加されたイベント リスナーの削除
JavaScript では、bind() メソッドを使用してイベント リスナーを追加できます。このメソッドは新しい関数参照を作成し、イベント リスナーが必要なコンテキストへのアクセスを保持できるようにします。ただし、このようなイベント リスナーを削除する場合、標準的なアプローチでは、bind() で追加された各リスナーを手動で追跡する必要があります。
バインド リスナー参照の追跡
次の 1 つの方法bind() で追加されたイベント リスナーを削除するのは、関数参照を追跡するためです。これには、バインドされた関数を保存する変数を維持し、リスナーを削除するときにそれを明示的に渡す必要があります。
<code class="js">// Store the bound function reference var clickListenerBind = this.clickListener.bind(this); // Add the event listener with the bound reference this.myButton.addEventListener("click", clickListenerBind); // Remove the event listener using the stored reference this.myButton.removeEventListener("click", clickListenerBind);</code>
より単純なアプローチ
手動によるより単純で直接的な代替手段リスナー参照の追跡には、バインドされた関数参照を変数に直接割り当てることが含まれます。これにより、他のイベント リスナーと同じ方法でリスナーを削除できます。
<code class="js">const listener = this.clickListener.bind(this); this.myButton.addEventListener("click", listener); this.myButton.removeEventListener("click", listener);</code>
このアプローチにより、追加の追跡変数が不要になり、最初に追加された方法に関係なく、一貫したイベント リスナーの削除が保証されます。
以上がJavaScriptの「bind()」で追加されたイベントリスナーを削除するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。