小米技术社区
小米技术社区管理员 关于小米

27岁,山西运城人,职业电商经理人,前端开发工作者,从事过网站建设、网络推广、SEO、SEM、信息流推广、二类电商、网络运维、软件开发,等相关电商工作,经验较为丰富,小米技术社区致力于为广大从事Web前端开发的人员提供一些力所能及的引导和帮助 ...[更多]

E-mail:mzze@163.com

Q Q:32362389

W X:xiaomi168527

小米技术社区大牛王飞 关于王飞

27岁,山西运城人,职业电商经理人,网络工程师兼运维,从事过运营商网络建设,企业网络建设、优化。数据中心网络维护等通过,经验丰富,座右铭:当自己休息的时候,别忘了别人还在奔跑。 ...[更多]

E-mail:wf_live@126.com

Q Q:3940019

微博:王小贱ss

小米技术社区设计小艳 关于小艳

大于花一样的年龄,河南郑州是我家,2010年在北京接触团购网,2011年进入天猫淘宝一待就是四年,如今已经将设计走向国际化(ps:误打误撞开始进入阿里巴巴国际站的设计,嘿嘿)五年电商设计,丰富经验,从事过天猫淘宝阿里各项设计,店铺运营,产品拍摄;我将我的经历与您分享是我的快乐!座右铭:越努力越幸运! ...[更多]

E-mail:97157726@qq.com

Q Q:97157726

标签云
精品推荐
  • 什么是闭包?js闭包的2个最大用途以及注意事项

    什么是闭包?js闭包的2个最大用途以及注意事项

    各种专业文献上的"闭包"(closure)定义非常抽象,很难看懂。简单的说,闭包就是能够读取其他函数内部变量的函数。由于在Javascript语言中,只有函数内部的子函数才能读取局部变量,因……
    199人已经看过了
您的位置:首页 > 前端开发 > Javascript > 原生JS

ES6中let和var声明变量的区别,let关键字声明块级变量

分类: 原生JS54个赞

相关阅读:ES6常量的定义,分类和作用

ES6中增加了let关键字声明变量,声明的变量只在当前代码块中生效(块级作用域)。

<script>
    if(true){
        let i=0;
        console.log(i);
    }
  console.log(i);//报错
</script>
<script>
    for(let i=0; i<=6; ++i){
        console.log(i);
    }
    console.log(i);//报错
</script>


使用let声明的变量可以重新赋值,但是不能在同一作用域内重新声明

<script>
    // let声明的变量可以重新赋值
    {
        let a = 1;
        console.log(a);
        a = 2;
        console.log(a);;
    }
</script>

<script>
  // let声明的变量不能在同一作用域重新声明,直接报错 预解析错误
  {
    let a = 1;
    console.log(a);
    let a = 2;
    console.log(a);
}
</script>


let声明变量和var声明变量的区别:

(1)作用域不一样,var是函数作用域,let是块作用域。

while(1){
let let1 = 2;
var var1 = 2;
}
alert(let1); //不可访问
alert(var1); //可以访问

(2)let不能在定义之前访问该变量,但是var可以。

(3)let不能被重新定义,但是var是可以的



let的特性:

(1)let变量没有变量提升

(2)let变量不能重复声明

(3)应用:let声明变量解决i丢失的问题

var arr = [3,4,5,6,7];

for(var i=0; i<arr.length; i++){
    (function(i){
        setTimeout(function(){
            console.log(i);
            //console.log(arr[i]);
        }, 1000);
   })(i);  //ES5中var声明解决for循环i丢失的问题只能用函数的自调用,
}


for(let i=0; i<5; i++){
        //设置定时器,1秒后,输出循环变量i的值
        //每次循环,都会产生一个块级作用域,其中的块级变量i 互相不影响
        setTimeout(function(){
            console.log(i);
        }, 1000);
    } //用let声明变量因为块级作用域,可以直接解决i变量丢失问题



总之呢,let从规范化的角度来说,要比var要进步了很大一步。

let关键字声明块级变量

小米技术社区

本站内容均为小米原创,转载请注明出处:小米技术社区>> ES6中let和var声明变量的区别,let关键字声明块级变量