es6种for循环中let和var区别

 let和var区别:javascript

 1 for(var i=0;i<5;i++){
 2    setTimeout(()=>{
 3         console.log(i);//5个5
 4     },100) 
 5 }
 6 console.log(i);//5
 7 console.log('=============')
 8 
 9 for(let j=0;j<5;j++){
10    setTimeout(()=>{
11         console.log(j);//0,1,2,3,4
12     },100) 
13 }
14 console.log(j);//报错 j is not defined

为何 用let就能够显示正确结果,而var就不能够呢?
var是全局做用域,有变量提高的做用,因此在for中定义一个变量,全局能够使用,循环中的每一次给变量i赋值都是给全局变量i赋值。

 let是块级做用域,只能在代码块中起做用,在js中一个{}中的语句咱们也称为叫一个代码块,每次循环会产生一个代码块,每一个代码块中的都是一个新的变量j;java

 es6中不是说let声明变量不能重复声明吗?看下边例子:es6

{
    let a=123;
}
{ let a
=246; } console.log(a);//a is not defined; { var b=1; } { var b=2; } console.log(b);// 2;

  {}表明一个块,这个时候let声明的变量只在这个块中起做用,而这个块对var声明的变量不起做用。由于var是全局做用域。spa

let a=1;
let a=2;
//Uncaught SyntaxError: Identifier 'a' has already been declared
//let不能重复声明

let b=1;
var b=2;

// Uncaught SyntaxError: Identifier 'a' has already been declared
//let不能重复声明


var c=3;
var c=4;
console.log(c)//4;var能够重复声明
相关文章
相关标签/搜索