es6 for循环中let和var区别详解

时间:2021-05-28

let和var区别:

for(var i=0;i<5;i++){ setTimeout(()=>{ console.log(i);//5个5 },100) }console.log(i);//5console.log('=============')for(let j=0;j<5;j++){ setTimeout(()=>{ console.log(j);//0,1,2,3,4 },100) }console.log(j);//报错 j is not defined

为什么 用let就可以显示正确结果,而var就不可以呢?

var是全局作用域,有变量提升的作用,所以在for中定义一个变量,全局可以使用,循环中的每一次给变量i赋值都是给全局变量i赋值。

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

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

{ 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是全局作用域。

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可以重复声明

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章