JavaScript は、定義前でも関数を使用できるという独特の動作を示します。 。この一見矛盾した現象はホイスティングとして知られています。
次のコードを考えてみましょう:
<code class="javascript">function fooCheck() { alert(internalFoo()); // We are using internalFoo() here... return internalFoo(); // And here, even though it has not been defined... function internalFoo() { return true; } //...until here! } fooCheck();</code>
このコードでは、internalFoo() 関数が fooCheck() 関数内で 2 回呼び出されています。その定義は、それらの呼び出しの後に配置されます。
この動作の背後にある理由は、JavaScript のホイスティング メカニズムにあります。コンパイル段階で、JavaScript は宣言をスコープの先頭にホイストします。この場合、これは fooCheck() 関数のスコープです。これは、internalFoo() 関数が最初の 2 つの呼び出しの後に物理的に配置されていても、スコープの先頭で宣言されているとみなされることを意味します。
この巻き上げ動作は関数宣言に固有であり、関数には適用されません。表現。たとえば、関数 innerFoo() 宣言を次の関数式で置き換えた場合:
<code class="javascript">var internalFoo = function() { return true; };</code>
関数式がホイストされないため、コードは失敗します。
関数宣言と関数宣言の区別式はホイスティングを理解する上で非常に重要です。関数宣言はステートメントとしてホイストされ、関数式は実行中に評価されます。
この動作は ECMAScript 標準のセクション 10.1.3 に文書化されています。ホイスティングにより、コード編成の柔軟性と効率が向上し、アクセシビリティに影響を与えることなく、スコープ内の任意の時点で関数を定義できるようになります。ただし、意図しない結果を避けるために、関数宣言と式の違いに注意することが重要です。
以上がJavaScript 関数を定義する前に使用できるのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。