js中var、let、const的区别

js中var、let、const的区别

  • 如果使用关键字 var 声明一个变量,那么这个变量就属于当前的函数作用域,如果声明是发生在任何函数外的顶层声明,那么这个变量就属于全局作用域。

    var a = 1; //此处声明的变量a为全局变量
    function foo(){
        var a = 2;//此处声明的变量a为函数foo的局部变量
        console.log(a);//2
    }
    foo();
    console.log(a);//1
    
  • 如果在声明变量时,省略 var 的话,该变量就会变成全局变量,如全局作用域中存在该变量,就会更新其值。如:

    var a = 1; //此处声明的变量a为全局变量
    function foo(){
        a = 2;//此处的变量a也是全局变量
        console.log(a);//2	
    }
    foo();
    console.log(a);//2
    
  • 提升是指无论 var 出现在一个作用域的哪个位置,这个声明都属于当前的整个作用域,在其中到处都可以访问到。注意只有变量声明才会提升,对变量赋值并不会提升。如下例所示:

    //该代码段跟下列代码段是一样的逻辑:
    console.log(a);//undefined
    var a = 1;
    
    var a;
    console.log(a);//undefined
    a = 1;
    
    // 而如果对未声明过的变量进行操作,就会报错
    console.log(b);//假设b未声明过,Uncaught ReferenceError: b is not defined
    
  • let 声明的变量,具有如下几个特点:

    • let 声明的变量具有块作用域的特征。
    • 在同一个块级作用域,不能重复声明变量。
    • let 声明的变量不存在变量提升,换一种说法,就是 let 声明存在暂时性死区(TDZ)。
    let a = 1;
    console.log(a);//1
    console.log(b);//Uncaught ReferenceError: b is not defined
    let b = 2;
    
    function foo(){
        let a = 1;
        let a = 2;//Uncaught SyntaxError: Identifier 'a' has already been declared
    }
    
  • 以下是一个经典的关于 var 和 let 的一个例子:

    for (var i = 0; i < 10; i++) {
        setTimeout(function(){
            console.log(i);
        },100)
    };
    // 该代码运行后,会在控制台打印出10个10.
    
    for (let i = 0; i < 10; i++) {
        setTimeout(function(){
            console.log(i);
        },100)
    };
    //则该代码运行后,就会在控制台打印出0-9.
    
  • const 声明方式,除了具有 let 的上述特点外,其还具备一个特点,即 const 定义的变量,一旦定义后,就不能修改,即 const 声明的为常量。

    const a = 1;
    console.log(a);//1
    a = 2;
    console.log(a);//Uncaught TypeError: Assignment to constant variable.
    
    //但是,并不是说 const 声明的变量其内部内容不可变,如:
    const obj = {a:1,b:2};
    console.log(obj.a);//1
    obj.a = 3;
    console.log(obj.a);//3
    
  • 总结

    • var 声明的变量属于函数作用域,let 和 const 声明的变量属于块级作用域;
    • var 存在变量提升现象,而 let 和 const 没有此类现象;
    • var 变量可以重复声明,而在同一个块级作用域,let 变量不能重新声明,const 变量不能修改。
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

teng28

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值