ES6 declaring variables before or in loop

Where and how should I declare new variables used in loops?

A:

const map = new Map(Object.entries(columns));
let cols;
for (let [key, value] of map)
{
    cols = value.split('|');
    //...
}

B:

const map = new Map(Object.entries(columns));
for (let [key, value] of map)
{
    let cols = value.split('|');
    //...
}

C:

const map = new Map(Object.entries(columns));
var cols;
for (let [key, value] of map)
{
    cols = value.split('|');
    //...
}

Probably A or B since everyone says let is the new var, but is there any difference between A and B?

Edited:
The variable cols will be used only inside for. I was wondering if there are some issues if variable is initialized inside loop (for example 100 times). So I wondered if it should be initialized outside loop. (A or B example)

The purpose is not to get access outside loop, but prevent (for example) 100 initialization variable cols inside loop (because let is used inside loop - case B).


In code snippet A, cols is accessible outside of the for too. As let variables are block-scoped, when used let to define variable inside for , the scope of the variable is for that block only. So, in B, the variable cols will not be accessible outside of the for .

C, is similar to A if cols is defined only once. If col is defined twice in the same scope using let will result in error.

Which one to use depends on the use-case.

  • If cols is needed inside for only, then use let cols = ...
  • If cols is needed outside of for too, use let cols; before for and then it can be used after for too in the same enclosing scope. Note that, in this case, cols will be the last value assigned in the loop.

  • The difference between A and B is the scope of the var. In first case you can access cols also outside the loop, in the second you can't.

    let a;
    
    for (let i =0; i < 2; i++) {
      let b = i;
      a = i;
    }
    
    console.log('a outside the loop:', a);
    console.log('b outside the loop:', b);
    console.log('i outside the loop:', i);  //If `var` was used instead of `let` then `i` would have had global scope
    链接地址: http://www.djcxy.com/p/35456.html

    上一篇: Pearson相关性在完全相关的集合中失败

    下一篇: ES6在循环之前或循环中声明变量