「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > ES6 ブロックレベルの関数セマンティクスは厳密モードと非厳密モードでどのように異なりますか?また、Web 拡張機能はそれらにどのような影響を与えますか?

ES6 ブロックレベルの関数セマンティクスは厳密モードと非厳密モードでどのように異なりますか?また、Web 拡張機能はそれらにどのような影響を与えますか?

2024 年 12 月 22 日に公開
ブラウズ:507

How Do ES6 Block-Level Function Semantics Differ in Strict and Non-Strict Modes, and How Do Web Extensions Affect Them?

ES6 ブロックレベル関数のセマンティクスを理解する

はじめに
ES6 の出現により、ブロック-level 関数宣言は、言語への貴重な追加機能になりました。初期の仮定にもかかわらず、これらの関数の正確なセマンティクスには、厳密モードと非厳密モードの区別やブラウザの互換性に関する考慮事項など、より広範囲が含まれます。

セマンティクス
次の表は、ブロックレベルの関数セマンティクスの重要な側面:

]
実行環境ブロックの外側に表示ブロックの先頭に持ち上げられますTDZ
非厳密、ウェブ拡張機能はありませんはい、いいねvarはいなし
厳密、ウェブ拡張機能なしいいえはいなし
非厳密、ウェブ拡張機能はい、var などはいなし
厳密なウェブ拡張機能いいえはい、2 回 (関数とブロック)関数スコープのバインディングは前に定義されていません宣言

ストリクト モードの影響
この文脈における「ストリクト モード」の概念は、関数自体の厳密さではなく、関数オブジェクトです。したがって、非厳密な周囲のコード内で「use strict」を含む関数宣言を含むコード スニペットは、引き続き「非厳密」とみなされます。

Web Extensions
The "web拡張機能」は、「正常な」関数ステートメントの外観を備えた厳密ではない (ずさんな) コードにのみ適用されます。 Web 互換性セマンティクスを備えただらしないモードでは、ブロック内の関数宣言は次のように処理されます:

  1. 関数宣言は字句ブロックの先頭に巻き上げられます。
  2. var 宣言
  3. 関数宣言が評価されると、関数オブジェクトは関数スコープの関数に割り当てられます。 variable.

本質的に、この動作により、同じ名前を持つ 2 つの個別のバインディングが生成されます。1 つはブロック スコープで、もう 1 つは関数スコープです。

結論
ES6 のブロックレベル関数は拡張機能を提供しますが、厳密なモードと Web 互換性の間の相互作用を含む、その正確なセマンティクスを理解することは、適切な使用を保証し、潜在的な可能性を回避するために重要です。落とし穴。

最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3