ECMAScript中let与var的区别
ECMAScript中let与var的区别
let是ECMAScript6中特有的语法,和var一样都有定义变量的作用,
相比var,对作用域的管理更规范。
let与var的共同点: 都可以定义变量
let与var的区别:
1、var变量可以跨代码块,let 只在代码块内部有效
{
var a="kerry";
let b=20;
}
console.log(a);//打印kerry
if(typeof(b)=="undefined"){//提示变量未定义
console.log("undefined");
}
2、在for循环里
//在for循环里
for (var i=0;i<5;i++){
}
console.log(i);//打印5
for (let j=0;j<5;j++){
}
console.log(j);//提示i变量未定义
3.定义顺序
console.log(a);//打印Undefined
var a="kerry";
console.log(b);//let 引用错误
let b="kerry";
案例展示:
var a=[];
for (var i=0;i<5;i++){
a[i]=function () {
console.log(i);
}
}
a[2]();//打印5
var b=[];
for (let j=0;j<5;j++){
a[j]=function () {
console.log(j);
}
}
b[2]();//打印2
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步