teratail header banner
teratail header banner
質問するログイン新規登録

回答編集履歴

2

グローバル変数の記述を削除

2020/05/05 02:18

投稿

shiracamus
shiracamus

スコア5406

answer CHANGED
@@ -1,4 +1,4 @@
1
- var はグローバル変数。forループを抜けても変数が存在し続けます。setTimeout は時間経過後に最終的な変数の値を表示します。
1
+ var はforループを抜けても変数が存在し続けます。setTimeout は時間経過後に最終的な変数の値を表示します。
2
2
  let はループ内だけで有効なローカル変数。forループを抜けると変数が破棄されてアクセスできなくなります、それでは困るので、setTimeoutに渡す関数を定義する毎にその時点の外部変数を抱え込むようになっています。これをクロージャといいます。なので、ループごとの変数の値を表示できます。
3
3
 
4
4
  以下のプログラムで変数の値と表示順序を確認してみるといいです。

1

確認コード追記

2020/05/05 02:18

投稿

shiracamus
shiracamus

スコア5406

answer CHANGED
@@ -1,2 +1,16 @@
1
1
  var はグローバル変数。forループを抜けても変数が存在し続けます。setTimeout は時間経過後に最終的な変数の値を表示します。
2
- let はループ内だけで有効なローカル変数。forループを抜けると変数が破棄されてアクセスできなくなります、それでは困るので、setTimeoutに渡す関数を定義する毎にその時点の外部変数を抱え込むようになっています。これをクロージャといいます。なので、ループごとの変数の値を表示できます。
2
+ let はループ内だけで有効なローカル変数。forループを抜けると変数が破棄されてアクセスできなくなります、それでは困るので、setTimeoutに渡す関数を定義する毎にその時点の外部変数を抱え込むようになっています。これをクロージャといいます。なので、ループごとの変数の値を表示できます。
3
+
4
+ 以下のプログラムで変数の値と表示順序を確認してみるといいです。
5
+
6
+ ```js
7
+ for (var i = 0; i < 3; i++) {
8
+ setTimeout(() => console.log(i), 1);
9
+ }
10
+
11
+ for (let i = 10; i < 13; i++) {
12
+ setTimeout(() => console.log(i), 1);
13
+ }
14
+
15
+ console.log("i =", i);
16
+ ```