0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

【javascript】letによる変数宣言

Last updated at Posted at 2020-06-07

こちらの記事は以下の書籍を参考に執筆しました
入門JavaScriptプログラミング

以下のコードはvarletそれぞれにのイテレータにより宣言されたfor文であるが、結果が異なる。

for (var i = 0; i < 5; i++) {
  setTimeout(function(){console.log("var:"+i)},1)
}

for (let n = 0; n < 5; n++) {
  setTimeout(function(){console.log("let:"+n)},1)
}

出典:入門JavaScriptプログラミング

#letのスコープの仕組み
letはブロックスコープである。
スコープは変数が宣言されたブロックまたはサブブロックの内側だけである。

これにより、ブロックの外側で使用されたためバグが紛れ込むということが無くなる。
また、以下のようにブロックにより変数をプライベートに保つことができる。

let read, write; 
{
  let data = {};//dataは実質的にプライベート変数

  write = function(key, val) {
    data[key] = val;
  }
  read = function(key) {
    return data[key];
  }
}

write(
  'message',
  'welcome to ES6'
);
read('message');
console.log(data);//ブロックの外でdataを参照しているためエラー

出典:入門JavaScriptプログラミング

##for文での例外
for文で宣言されたlet変数のスコープはforループのブロックとなる。

for (let i = 0; i < 5; i++) {
  console.log(i);//iのスコープはforブロック
}

console.log(i);//エラー

出典:入門JavaScriptプログラミング

##letが推奨される理由
var関数スコープ
そのため、変数には宣言された変数のどこからでもアクセスできる。

(function(){
  if (true){
    var foo='bar';
  }
  console.log(foo);//ifブロックの外からアクセス可能
}());

出典:入門JavaScriptプログラミング

以下はvarの典型的な例である。

<ui>
  <li>one</li>
  <li>two</li>
  <li>three</li>
  <li>four</li>
  <li>five</li>
</ui>
<script type="text/javascript">
  var items = document.querySelectorAll('li');
  for (var i = 0; i < 5; i++) {
    var li = items[i];
    li.addEventListener('click', function() {
      alert(li.textContent + ':' + i);
    })
  }
</script>

出典:入門JavaScriptプログラミング

どのliタグをクリックしてもfive:5と表示される。

イベントリスナはfor文が完了するまで呼び出されず、i``li.textontentが表示される頃にはそれぞれ5とfiveが設定されているためである。

##変数のシャドーイング
以下のコードを実行すると2つ目の"scope"は実行されない

var words = ["function", "scope"];
for (var i = 0; i < words.length; i++) {
  var word = words[i];
  for (var i = 0; i < word.length; i++) {
    var char = word[i];
    console.log('char', i, char);
  }
}

出典:入門JavaScriptプログラミング

2つ目のforループが完了した際にはiは7になっているため。
この場合両方letで宣言してあげると解決できるが、これは変数のシャドーイングと呼ばれ、一般的には悪い作法だ。
内側のループには別の変数名を定義すべき。

0
0
1

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?