ES6 ブロックレベル関数のセマンティクスを理解する
はじめに
ES6 の出現により、ブロック-level 関数宣言は、言語への貴重な追加機能になりました。初期の仮定にもかかわらず、これらの関数の正確なセマンティクスには、厳密モードと非厳密モードの区別やブラウザの互換性に関する考慮事項など、より広範囲が含まれます。
セマンティクス
次の表は、ブロックレベルの関数セマンティクスの重要な側面:
実行環境 | ブロックの外側に表示 | ブロックの先頭に持ち上げられます | TDZ |
---|---|---|---|
非厳密、ウェブ拡張機能はありません | はい、いいねvar | はい | なし |
厳密、ウェブ拡張機能なし | いいえ | はい | なし |
非厳密、ウェブ拡張機能 | はい、var など | はい | なし |
厳密なウェブ拡張機能 | いいえ | ]はい、2 回 (関数とブロック) | 関数スコープのバインディングは前に定義されていません宣言 |
ストリクト モードの影響
この文脈における「ストリクト モード」の概念は、関数自体の厳密さではなく、関数オブジェクトです。したがって、非厳密な周囲のコード内で「use strict」を含む関数宣言を含むコード スニペットは、引き続き「非厳密」とみなされます。
Web Extensions
The "web拡張機能」は、「正常な」関数ステートメントの外観を備えた厳密ではない (ずさんな) コードにのみ適用されます。 Web 互換性セマンティクスを備えただらしないモードでは、ブロック内の関数宣言は次のように処理されます:
本質的に、この動作により、同じ名前を持つ 2 つの個別のバインディングが生成されます。1 つはブロック スコープで、もう 1 つは関数スコープです。
結論
ES6 のブロックレベル関数は拡張機能を提供しますが、厳密なモードと Web 互換性の間の相互作用を含む、その正確なセマンティクスを理解することは、適切な使用を保証し、潜在的な可能性を回避するために重要です。落とし穴。
免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。
Copyright© 2022 湘ICP备2022001581号-3