ホームページ > ウェブフロントエンド > jsチュートリアル > ES6 ブロックレベルの関数宣言はホイスティング、可視性、厳密モードに関してどのように動作しますか?

ES6 ブロックレベルの関数宣言はホイスティング、可視性、厳密モードに関してどのように動作しますか?

Barbara Streisand
リリース: 2024-12-09 17:59:18
オリジナル
574 人が閲覧しました

How Do ES6 Block-Level Function Declarations Behave Regarding Hoisting, Visibility, and Strict Mode?

ES6 のブロックレベル関数の正確なセマンティクス

ES6 では、ブロックレベルの関数宣言により、従来の関数宣言と比較して新しいセマンティクスがもたらされます。この記事では、これらの関数の正確な動作を詳しく掘り下げ、その可視性、ホイスティング、およびブロックレベル関数のコンテキストにおける「厳密モード」の概念に関する質問に対処します。

セマンティクスの表

提供された情報に基づいて、Web の有無にかかわらず厳密モードと非厳密モードを考慮したブロックレベル関数の動作を次の表に要約できます。 extensions:

Mode Visible Outside of Block? Hoisted? TDZ?
Non-strict, No Web Extensions No Hoisted to block No
Strict, No Web Extensions No Hoisted to block No
Non-strict, With Web Extensions Yes * Hoisted twice (to function and block) No
Strict, With Web Extensions Yes * Hoisted twice (to function and block) No

* 関数スコープの変数として表示されますが、ブロックスコープのバインディングもあります。

「厳密モード」の定義の明確化

コンテキスト内ブロックレベル関数の「厳密モード」とは、関数宣言を含むブロックが出現する関数またはスクリプトの厳密性を指します。ブロック内で宣言されている関数の厳密性については言及しません。

Web 拡張機能とずさんなコード

「Web 拡張機能」の概念は、ずさんな (厳密ではない) コードにのみ適用されます。 。このコンテキストでは、スロシー モードのブロック内の関数宣言は、Web 拡張機能で次のような動作をします:

  1. 関数宣言は、ブロックとそれを囲んでいる関数の両方の先頭にホイストされます。
  2. 関数と同じ名前の関数スコープ変数もホイストされます。
  3. 関数宣言が評価されると、関数は関数スコープ変数。

結論

ES6 のブロックレベル関数のセマンティクスを理解することは、明確で予測可能なコードを作成するために不可欠です。この記事は、Web 拡張機能と厳密モードの概念によってもたらされる潜在的な複雑さを強調しながら、これらの関数の正確な動作を明確にすることを目的としています。これらのセマンティクスに従うことで、開発者は潜在的な落とし穴を回避し、ES6 のブロックレベル関数の利点を活用する堅牢なコードを作成できます。

以上がES6 ブロックレベルの関数宣言はホイスティング、可視性、厳密モードに関してどのように動作しますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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