es6中的let 和 var 的区别

本文通过实例对比了ES6中let与var的作用域差异,解析了它们在代码块内外的访问特性,并介绍了const的使用特点。

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

好久没有更新博客了,哭 最近公司赶项目,天天熬夜加班.........

今天公司里一个小伙伴,偶然间提到了ES6中的let 和 var 的区别,给她解释了半天,今天就但拉出来写一个总结,也算给我的小伙伴整理一下。奋斗

在ES6中var 和 let 用法都一样,为什么我们还要用let呢?

下面偶奏来说一说他们的区别;

举两个栗子大家就明白了:

用var 声明的变量

if(true){  

   var a = 1;  

   console.log(a);//1 可以访问到  

}  

   console.log(a);//1 可以访问到  

用let声明的变量


if(true){  

   let a = 1;  

   console.log(a);//1 可以访问到  

}  

   console.log(a);// 不可以


上面的这两个栗子,我们可以看出:
用var 声明的a 在包裹它的作用域空间外(代码块外)可以访问到;

而let 声明的a 在包裹它的作用域空间外(代码块外)不可以访问到;


还有就是let不可以同名,而var 可以同名(只不过前一个声明的会被覆盖);
举栗子:


var a = 1;  

var a =2 ;  

console.log(a);//2  

 
let b = 1;  

let b = 2;  

console.log(b);//(报错鸟)caught SyntaxError: Identifier 'a' has already been declared</span>  

说完了let 和 var 的区别,接下来说说 const ;

const 是一个常量,只能声明一次,而且不能重复声明,而且不能更改;


const a = 1;  

const a = 2;  

console.log(a);//报错

但是如果定义的常量是一个对象,我们去修改这个常量里的值 不会报错;

const a ={  

     b:10  

}  

a.b=11;  

console.log(a.b)//11  


如果有什么地方说的不得体,欢迎大家指出; 再见


### 变量作用域 `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]。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值