多くの開発者は、パフォーマンス上の懸念、潜在的なセキュリティ リスク、および非推奨であるため、setTimeout に文字列を渡す習慣に眉をひそめています。状態。ただし、この構文が有益なシナリオがまれに存在する可能性があります。
setTimeout と setInterval の従来の構文では、実行するコードを表す文字列を渡す必要がありました。例:
<code class="javascript">setTimeout('doSomething(someVar)', 10000);</code>
ただし、最新の JavaScript では代わりに関数参照の使用が推奨されています。
<code class="javascript">setTimeout(function() { doSomething(someVar); }, 10000);</code>
推奨される構文から逸脱する正当な理由がある場合。考えられる引数の 1 つは、グローバル スコープ内に存在するが、ローカルでオーバーライドされた可能性がある関数または変数にアクセスしたいという要求です。
この理論的根拠にもかかわらず、文字列の使用はsetTimeout では使用しないことを強くお勧めします。グローバル変数には、ウィンドウ オブジェクトのプロパティを通じて引き続きアクセスできます。例:
<code class="javascript">setTimeout(window.doSomething(someVar), 10000);</code>
setTimeout および setInterval の引数として文字列を許可することは、歴史的要因に根ざしている可能性があります。 JavaScript の初期バージョンでは文字列のみがサポートされていました。関数参照を渡す機能の追加は後から追加されたものです。下位互換性を確保するために、ブラウザでは文字列構文が非推奨になっても引き続き使用できます。
特定のケースでは文字列を setTimeout に渡すことは技術的には可能ですが、一般的には行われません。代替アプローチが利用できるため、推奨されます。関数参照を使用すると、パフォーマンスが向上し、セキュリティが強化され、最新のコード ガイドラインに準拠します。したがって、明確さ、保守性、全体的なコード品質を考慮して、非推奨の文字列構文は避ける必要があります。
以上がsetTimeout に文字列を渡す必要があるでしょうか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。