var、let 、const的区别

本文详细解释了JavaScript中let和const的关键区别,包括块级作用域、变量提升、全局属性、重复声明、暂时性死区以及它们在初始化设置和指针指向上的差异。推荐使用let处理块级作用域和计数,const用于常量和对象类型声明。

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

1、作用域的区别

letconst具有块级作用域,var不存在块级作用域,可以跨块访问, 不能跨函数访问

      if(true){
            var a = 0
            let b = 0
            const c = 0
        }
        console.log(a);
        console.log(b);
        console.log(c);

这里只有var声明的变量才能打印出来,因为var声明的是全局变量

var出来的变量是全局的,但是不能跨函数访问

    function test() {
              var message = "zimo";   // 局部变量
             }
        test();
        console.log(message);  // 报错

2、变量提升

什么是变量提升?

变量能在声明之前使用,就是变量提升。

var存在变量提升,let和const不存在变量提升

        console.log(a);
        console.log(b);
        console.log(c);
 
        var a = 1
        let b = 2
        const c = 3

var在js中是支持预解析的声明出来的就不会报错是undefined,let,const就会报错

3、全局属性

浏览器的全局对象是window,var声明的变量是全局变量,并且会将该变量添加为全局对象的属性,但是let和const不会

        var a = 1
        let b = 2
        const c = 3
 
        console.log(window.a);
        console.log(window.b);
        console.log(window.c);

4、重复声明

var声明变量时可以重复声明变量,后声明的同名变量会覆盖之前声明的遍历,const和let不允许重复声明变量

        var a = 1
        var a = 2
 
        console.log(a);

var声明的变量同名只会打印最后一次声明的值

 let 和 const同一个作用域下不能重名,编辑器都提示了

5、暂时性死区

在使用let、const命令声明变量之前该变量都是不可用的。这在语法上,称为暂时性死区。使用var声明的变量不存在暂时性死区

        // name会被提升
        console.log(name); // undefined
        var name = 'zimo';
 
        // age不会被提升
        console.log(age); // ReferenceError:age没有定义
        let age = 18;
 
        // sex不会被提升
        console.log(age); // ReferenceError:age没有定义
        const sex = "男";

6、初始化设置

声明变量时,var和let可以不用设置初始值。而const声明变量必须设置初始值

7、指针指向

指针指向:let和const都是ES6新增的勇于创建变量的语法。let创建的变量是可以更改指针指向(可以重新赋值)但const声明的变量是不允许改变指针的指向

8、应用场景

块级作用域解决了ES5中的两个问题:

 内层变量可能覆盖外层变量

 用来计数的循环变量泄露为全局变量

应用场景:以后声明变量用let就对了

应用场景:声明对象类型使用const,非对象类型声明使用let

没有特殊情况就不要使用var了

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值