javascript关于var与let[0701]
一、开解:
这两个东西一直困惑了许多人,这里我简单讲解一下它们之间的区别。
1、作用域不同,var是函数级作用域,let是块级作用域。
2、var可重复声明,let不能重复声明,var在重复声明后会被提升。
我们通过实例来了解一下它们之间的区别。
二、实例:
/
function test() {
for (var i = 0; i < 6; i++) { }
alert(i);
};//这里的i是var声明,所以在test函数内都有效,alert弹出正常
/
function test() {
for (let i = 0; i < 6; i++) {
console.log("let在这里有效,i="+i);
}
alert(i);
};//这里的i是let声明,所以在for块内{}都有效,alert不能弹出
/
var i = "方块网页"
function test() {
console.log(i);
var i;
};//这里运行后显示“undefined”,var可重复声明,log里的i被提升了;
/
let i = "方块网页";
let i = "是我";
function test() {
console.log(i);
};//这里会提示代码出错,无法运行,因为不允许两次let声明i;
/
var i = "方块网页";
var i = "是我";
function test() {
console.log(i);
};//这里会输出“是我”,不会有let的错误;
三、总结:
Let是在ES6出现的,它让自由的javascript没那么自由(有时候自由未必是好事),它让javascript更为严谨,所以let比var会用得更为广泛。