ホームページ > ウェブフロントエンド > jsチュートリアル > JavaScript の独自の定義内からイベント リスナーを削除するにはどうすればよいですか?

JavaScript の独自の定義内からイベント リスナーを削除するにはどうすればよいですか?

Mary-Kate Olsen
リリース: 2024-12-05 14:13:11
オリジナル
306 人が閲覧しました

How to Remove an Event Listener from Within Its Own Definition in JavaScript?

JavaScript でのイベント リスナーの削除

JavaScript では、ユーザー インタラクションに応答するためにイベント リスナーが一般的に使用されます。ただし、さまざまな理由でこれらのリスナーを削除する必要がある場合があります。

問題:

イベント リスナーをイベント リスナーの定義内から削除したいと考えています。リスナーそのもの。ただし、リスナー内で 'this' を使用しようとするとエラーが発生します。

解決策 1: 名前付き関数

この問題を解決するには、匿名関数の代わりに名前付き関数を使用します。 :

var click_count = 0;

function myClick(event) {
    click_count++;
    if (click_count == 50) {
        // Remove the event listener
        canvas.removeEventListener('click', myClick);
    }
}

// Add the event listener
canvas.addEventListener('click', myClick);
ログイン後にコピー

このソリューションでは、「click_count」変数がリスナーの外部で定義され、関数内での可視性が確保されています。また、「myClick」は名前付き関数なので、後で削除できます。

解決策 2: クロージャ

または、クロージャを使用してこれを実現できます。

var myClick = (function (click_count) {
    var handler = function (event) {
        click_count++;
        if (click_count == 50) {
            // Remove the event listener
            canvas.removeEventListener('click', handler);
        }
    };
    return handler;
})(0);

// Add the event listener
canvas.addEventListener('click', myClick);
ログイン後にコピー

このアプローチでは、「click_count」変数の周囲にクロージャが作成されます。 「ハンドラー」関数はカウンターをインクリメントし、必要に応じてイベント リスナーを削除します。

解決策 3: 個別のカウンター

各要素が独自のカウンターを必要とする場合は、この解決策を利用してください。 :

var myClick = function (click_count) {
    var handler = function (event) {
        click_count++;
        if (click_count == 50) {
            // Remove the event listener
            canvas.removeEventListener('click', handler);
        }
    };
    return handler;
};

// Add the event listener with a unique click counter for each element
canvas.addEventListener('click', myClick(0));
ログイン後にコピー

以上がJavaScript の独自の定義内からイベント リスナーを削除するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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