es6 for循环中let和var区别详解
let和var区别:
for(var i=0;i<5;i++){
setTimeout(()=>{
console.log(i);//5个5
},100)
}
console.log(i);//5
console.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可以重复声明
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
JavaScript设置IFrame高度自适应(兼容各主流浏览器)
IFrame高度的设置问题一直都是前端的噩梦而且还要兼容各主流浏览器更是难上加难了,下面与大家分享下一个不错的技巧,感兴趣的你可以参考下哈2013-06-06
HTML5 Shiv完美解决IE(IE6/IE7/IE8)不兼容HTML5标签的方法
这篇文章主要介绍了HTML5 Shiv完美解决IE(IE6/IE7/IE8)不兼容HTML5标签的方法,需要的朋友可以参考下2015-11-11
使用mixins实现elementUI表单全局验证的解决方法
这篇文章主要介绍了使用mixins实现elementUI表单的全局验证的解决方法,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下2019-04-04


最新评论