変数宣言を使用しないオブジェクトの構造化
JavaScript では、オブジェクトの構造化を使用してオブジェクトからプロパティを抽出できます。ただし、変数宣言 (var、let、const など) を先行させずにオブジェクトの構造化を使用すると、SyntaxError が発生する可能性があります。
これは、JavaScript では {...} 演算子が複数の意味を持つ可能性があるためです。ステートメントの先頭にある場合は、割り当てできないブロックを表します。ただし、ステートメントの後半で式として出現する場合は、オブジェクトを表します。
次の例では、{a, b} がオブジェクトではなくブロックとして解釈されるため、エラーがスローされます。
{a, b} = {a: 1, b: 2};
このエラーを回避するには、かっこを使用して {a, b} 式をグループ化します。
( {a, b} = {a: 1, b: 2} );
または、次のようにすることもできます。変数宣言:
var {a, b} = {a: 1, b: 2};
おまけの質問に関しては、中括弧とは異なり、角括弧は常に式として解釈されるため、配列の構造化には事前の変数宣言は必要ありません。したがって、次の例は有効です。
[c, d] = [1, 2];
提供された関数の例では、{a, b} 式はステートメントの先頭に出現するため、ブロックとして解釈されます。その結果、a と b をブロック内の新しい値に再代入することはできません。
以上が変数宣言なしでオブジェクトの構造化を使用すると、JavaScript が SyntaxError をスローするのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。