JSのletとvarの違い

下次还敢
下次还敢オリジナル
2024-05-01 05:21:15732ブラウズ

let と var で宣言された変数の主な違いはスコープです。let で宣言された変数は、宣言されたブロック レベルのスコープ内でのみ表示されますが、var で宣言された変数はグローバル スコープまたは関数スコープを持ちます。さらに、 let は再宣言を許可しませんが、 var は再宣言と割り当てを許可します。

JSのletとvarの違い

#let と var の違い

let と var は JavaScript で変数を宣言するための 2 つのキーワードです。スコープ、ホイスティング、および再宣言における主な違いは次のとおりです。

Scope

  • var: var で宣言された変数はグローバル スコープを持ちます。宣言された場所に応じて、または関数スコープ。
  • let: let で宣言された変数は、宣言されたブロック レベルのスコープ (中括弧) 内でのみ表示されます。

プロモーション

  • var: var で宣言された変数は、コードを実行する前に関数またはグローバル スコープにプロモートされます。のトップ。
  • let: let で宣言された変数はプロモートされず、宣言されたスコープ内でのみ使用可能です。

再宣言

  • var: var で宣言された変数は、同じスコープ内で再宣言でき、上書きされます。 前のステートメント。
  • let: let で宣言された変数を同じスコープ内で再宣言することはできないため、エラーがスローされます。

その他の相違点

上記の主な相違点に加えて、let と var には次のようなその他の相違点もあります。

  • 再割り当て: let で宣言された変数は再割り当てでき、var で宣言された変数は再割り当ておよび再宣言できます。
  • 初期値: let で宣言された変数は宣言時に初期化する必要がありますが、var で宣言された変数は初期化されず、デフォルトで未定義になる場合があります。

<code class="javascript">// 使用 var
function example1() {
  var x = 10;
  if (true) {
    var x = 20; // 重新声明和重新赋值
    console.log(x); // 输出: 20
  }
  console.log(x); // 输出: 20
}

// 使用 let
function example2() {
  let y = 10;
  if (true) {
    let y = 20; // 重新赋值
    console.log(y); // 输出: 20
  }
  console.log(y); // 输出: 10
}</code>
例に示すように、var では同じスコープ内の変数の再宣言と再代入が可能ですが、 let では再代入のみが可能です。

以上がJSのletとvarの違いの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。