JavaScript で setTimeout を使用するときに「this」参照を保持するにはどうすればよいですか?

Mary-Kate Olsen
リリース: 2024-10-24 11:35:29
オリジナル
795 人が閲覧しました

How to Preserve the

setTimeout と JavaScript のとらえどころのない「this」

setTimeout 関数を使用すると、開発者は、後続のメソッド呼び出しが失われるという問題に遭遇することがよくあります。意図したコンテキストにより、一見未定義のメソッドが生成されます。これは通常、「this」参照が失われたことが原因で発生します。

問題:

次のコードを考えてみましょう:

test.prototype.method = function() {
    //method2 returns image based on the id passed
    this.method2('useSomeElement').src = "http://www.some.url";
    timeDelay = window.setTimeout(this.method, 5000);
};

test.prototype.method2 = function(name) {
    for (var i = 0; i < document.images.length; i++) {
        if (document.images[i].id.indexOf(name) > 1) {
            return document.images[i];
        }
    }
};
ログイン後にコピー

On最初のページ読み込みでは、method2 関数は意図したとおりに機能します。ただし、タイムアウトを設定した後、メソッド 2 を呼び出すと、メソッド 2 が未定義であることを示すエラーが発生します。

解決策:

中心的な問題は、setTimeout の処理方法にあります。このキーワード。 setTimeout(this.method, 5000) を使用してタイムアウトを設定すると、コンテキストが失われ、エラーが発生します。

この問題に対する賢明な解決策は、bind() メソッドを使用することです。メソッド呼び出しの最後に「.bind(this)」を追加すると、コンテキストを明示的にバインドでき、タイムアウト後も正しい「this」参照が確実に維持されます。

コードの改善:

test.prototype.method = function() {
    //method2 returns image based on the id passed
    this.method2('useSomeElement').src = "http://www.some.url";
    timeDelay = window.setTimeout(this.method.bind(this), 5000);
    //                                       ^^^^^^^^^^^ <- fix context
};
ログイン後にコピー

この変更により、「this」のコンテキストが適切にバインドされ、タイムアウトが経過した後もメソッド 2 が意図したとおりに機能し続けることができるようになります。このアプローチは洗練されており、正しい実行コンテキストを保持するのに効果的です。

以上がJavaScript で setTimeout を使用するときに「this」参照を保持するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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