在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
前言:
1.作用域表现形式不同var是函数作用域,let是块级作用域 { var monkey='熏悟空'; let pig='猪扒盖'; } console.log(monkey); //输出undefined console.log(pig); //报错:pig is not deined 由上面代码可见, 2.是否变量提升的区别var声明的变量会进行变量提升,let声明的变量不会进行变量提升。 console.log(monkey); //undefined var monkey='熏悟空'; console.log(pig); //报错:pig is not defined let pig='猪扒盖'; 同样的逻辑,为什么var声明的变量在它声明之前调用会显示未定义,而let声明的变量在声明之前调用会抛出异常呢,这就是两者在变量提升上的区别,var声明的变量存在变量提升,let声明的变量不存在变量提升。 那么什么叫变量提升呢,我这里不做概念性的描述,我只说我个人的理解,就是以上代码实际上相当于如下: var monkey; console.log(monkey); //undefined monkey='熏悟空'; console.log(pig); //报错:pig is not defined let pig='猪扒盖'; 看见区别了吗,var声明的变量会将声明的变量提取到作用域的最上面进行定义但不赋值,赋值操作还是在你的代码处,所以你在调用 3.暂时性死区上的区别暂时性死区:如果在某一作用域内let了一个变量,如果外部作用域中有相同名称的变量,那么就算在作用域内进行了更改,也不会影响到外部作用域 具体表现如下: for(var i=0;i<5;i++){ setTimeout(function(){ console.log(i) },1000) } for(let i=0;i<5;i++){ setTimeout(function(){ console.log(i) },1000) } 请问这两处代码的运行结果分别是什么? 第一处代码运行完毕的结果是1s后顺序打印5个5;第二处代码运行完毕的结果是1s后顺序打印0,1,2,3,4。 请问为什么会存在这种区别? 因为第一处代码的变量i由var关键字声明,不存在关键性死区,即你在1s后 而第二处代码的变量i由let关键字声明,产生了关键性死区,存在 4.在同一个上下文中var可以重复声明,let不行let monkey='熏悟空'; let monkey='逼马吻'; //报错:Identifier 'a' has already been declared var pig='猪扒盖'; var pig='猪肛裂'; //正常访问,变量pig的值被替换 到此这篇关于JavaScript中var与let的区别的文章就介绍到这了,更多相关JavaScript中var与let内容请搜索极客世界以前的文章或继续浏览下面的相关文章希望大家以后多多支持极客世界! |
请发表评论