es6新增的let,const与var的区别

JavaScript中的let与const命令详解
本文详细介绍了JavaScript中的let和const命令,包括它们的作用域、变量提升和暂时性死区等特性。let限制了变量的作用域,只在声明的代码块内有效,并不会变量提升。const则用于声明不可变的常量,一旦赋值后无法更改。同时,文章强调了在函数内部重新声明let和const变量以及对参数的限制。通过对这两个关键字的理解,开发者可以更好地组织和优化代码。

//let与var的区别

     //1.所声明的变量只在let所在的代码块内有效
        {
            let a = 1;
            var b = 2;
        }
        a //error
        b; //1
        //2.不存在变量提升
        {
            // var 可以变量提升
            console.log(a); //undefined
            var a = 1;
            //let 不存在变量提升,会报错
            console.log(b);
            let b; //error
        }
        // 3.暂时性死区
        //如果区块中存在let和const的命令,则这个区块对这些命令声明的变量从一开始就形成封闭作用域。只要在声明之前使用这些变量,就会报错,俗称暂时性死区(TDZ)

{
tem = 123; //error
console.log(tem); //error

let tem; //TDZ结束
console.log(tem); //undefined

tem = 456;
comsole.log(tem); //456
}

//不允许重复声明变量

//报错
function() {
let a = 10;
var a = 20;
}

//报错
function() {
let a = 10;
let a = 20;
}

//不能在函数内部重新声明参数
function(a) {
let a = 10; //报错
}

const命令

const声明一个只读的常量,一旦声明,常量的值就不能改变。
const a = 1;
a = 2;//error



### 变量作用域 `var` 关键字声明的变量具有函数作用域或全局作用域,这意味着如果在函数内部没有使用 `var` 声明变量,则会创建一个全局变量。而 `let` `const` 都具有块级作用域,这使得它们更适合于循环条件语句中的变量声明,因为它们不会泄露到外部作用域[^1]。 ```javascript if (true) { var x = 5; let y = 6; } console.log(x); // 5 console.log(y); // ReferenceError: y is not defined ``` ### 变量提升 使用 `var` 声明的变量会被提升到其作用域的顶部,并且初始化为 `undefined`。相比之下,`let` `const` 虽然也会被提升,但不会被初始化,因此访问这些变量会导致引用错误,直到它们被实际执行流中的声明所覆盖(暂时性死区)[^3]。 ```javascript console.log(a); // undefined var a = 10; console.log(b); // ReferenceError let b = 20; ``` ### 重复声明 `var` 允许在同一作用域内重复声明同一个变量,而 `let` `const` 则不允许这样做。尝试这样做会导致语法错误。 ```javascript var c = 1; var c = 2; // 合法 let d = 3; let d = 4; // SyntaxError: Identifier 'd' has already been declared ``` ### 不可变性 `const` 声明的变量必须立即初始化,并且一旦赋值后就不能更改其绑定的对象。然而,如果是对象或数组,虽然不能改变引用本身,但是可以修改对象属性或数组的内容[^4]。 ```javascript const e = { name: "Alice" }; e.name = "Bob"; // 合法 e = { name: "Charlie" }; // TypeError: Assignment to constant variable. ``` ### 使用建议 由于 `let` `const` 提供了更好的作用域控制避免了一些常见的编程陷阱,如变量提升带来的问题,因此推荐优先使用 `const`,只有当需要重新赋值时才使用 `let`。不再推荐使用 `var` 来声明变量[^2]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值