var, let, const三者之间的区别

博客介绍了JS中的作用域,包括全局作用域和局部作用域。详细对比了var和let的异同,var是全局声明,存在变量提升,可重复声明;let是局部声明,无变量提升,禁止重复声明。还说明了const用于定义常量,需初始化,只能在块级作用域访问,不可重复声明。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

  

一   作用域

  js中有全局作用域和局部作用域两种,

  var和let

  相同点:   都是用来声明变量

  不同点: 

   (1) var 是全局声明。 let是局部声明,只在声明的块中有效(块级作用域)

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

 

  

   (2)   var声明存在变量提升。   let 声明不存在变量提升

    console.log(a);       //     undefined
    console.log(b)        //     Uncaught ReferenceError: Cannot access 'b' before initialization  初始化之前无法访问“b”

    var a = 1;
    let b = 2;

     (3)    let 禁止重复声明变量  

function fn (){
   var a = 1;
   let a = 2;
   console.log(a); //SyntaxError
}

function fn (){
   let a = 1;
   let a = 2;
   console.log(a); //SyntaxError
}

function fn (a){
   let a = 2;
   console.log(a); //SyntaxError
}

  const

   const用来定义常量,使用是必须初始化(即必须赋值),同样只能在块级作用域里访问,一旦设置了就不能在修改了(不可重复声明)

<script type="text/javascript">
    // 块作用域
    {
        var a = 1;
        let b = 2;
        const c = 3;
        // c = 4; // 报错
        var aa;
        let bb;
        // const cc; // 报错
        console.log(a); // 1
        console.log(b); // 2
        console.log(c); // 3
        console.log(aa); // undefined
        console.log(bb); // undefined
    }
    console.log(a); // 1
    // console.log(b); // 报错
    // console.log(c); // 报错
 
    // 函数作用域
    (function A() {
        var d = 5;
        let e = 6;
        const f = 7;
        console.log(d); // 5
        console.log(e); // 6  
        console.log(f); // 7 
 
    })();
    // console.log(d); // 报错
    // console.log(e); // 报错
    // console.log(f); // 报错
</script>

  

转载于:https://www.cnblogs.com/ly-qingqiu/p/10919188.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值