ホームページ >ウェブフロントエンド >jsチュートリアル >JavaScript で setTimeout を使用するときに「this」参照を保持するにはどうすればよいですか?

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

Mary-Kate Olsen
Mary-Kate Olsenオリジナル
2024-10-24 11:35:29826ブラウズ

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 サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。