js中var 与 let ,const的区别

本文详细介绍了JavaScript中var、let和const的区别,包括作用域、变量提升、重复声明及赋值等方面。var声明的变量在全局范围内有效,存在变量提升,可以重复声明但不推荐重复赋值。let和const则在块级作用域内生效,无变量提升,不允许重复声明,let允许重新赋值,而const一旦初始化后不能更改。理解这些差异对于编写高质量的JavaScript代码至关重要。
摘要由CSDN通过智能技术生成

一、var声明的变量在全局范围内有效,let和const只在声明其所在的块级作用域内有效。

    if(1) {
      let a = 1
      var b = 1
      console.log(a)  //1
    }
    console.log(a); //a is not defined
    if(1) {
      let a = 1
      var b = 1
      console.log(a)  //1
    }
    console.log(b);  //1

二、var有变量提升,let和const没有变量提升。

    console.log(a); // undefined  ===>  a已声明还没赋值,默认得到undefined值
    var a = 100;
    console.log(b); //报错:Cannot access 'b' before initialization ===> 初始化前无法访问'b'
    let b = 10;
    console.log(c); //报错:Cannot access 'c' before initialization ===> 初始化前无法访问'c'
    const c = 10;

三、var允许重复声明同一变量,let和const不允许重复声明同一变量;var和let允许重复赋值同一变量,const在初始化赋值后不能再给这个变量赋值。

    const a = 1
    const a = 2 //报错: Identifier 'a' has already been declared ===> 'a'已经声明过了
    const b //报错:Missing initializer in const declaration ===> 声明常量时未初始化
    let c = 2
    let d //无报错
    c = 7 //无报错
    c = 9 //无报错
    let c = 3 //报错: Identifier 'c' has already been declared ===> 'c'已经声明过了
    var e = 4 
    var e = 5 //无报错
    e = 6 //无报错
    e = 7 //无报错

四、const声明一个只读的常量,声明时必须初始化

    const a = 1 
    a = 2 //报错:Assignment to constant variable ===> 常数变量赋值
    const b //报错:Missing initializer in const declaration ===> 在声明常量时未初始化
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值