JavaScript中let的用法

本文介绍了ES6中let关键字的引入,其块级作用域特性,以及与var的区别。重点讲解了let声明的变量不会被提升,以及在for循环和作用域外访问变量的不同结果。同时,提到了变量提升在var中的表现和let避免这个问题的优势。

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

1、let的引入

ES6 新增了let命令,用来声明变量。它的用法类似于var,但是所声明的变量,只在let命令所在的代码块内有效。

2、基本用法

{
  let a = 10;
  var b = 1;
}
a // ReferenceError: a is not defined.
b // 1

上面代码在代码块之中,分别用letvar声明了两个变量。然后在代码块之外调用这两个变量,结果let声明的变量报错,var声明的变量返回了正确的值。这表明,let声明的变量只在它所在的代码块有效。

我们在使用for循环的计数器时,就很适合使用let命令,如下:

for (let i = 0; i < 10; i++) {
  // ...
}
console.log(i);
// ReferenceError: i is not defined

上面代码中,计数器i只在 for循环体内有效,在循环体外引用就会报错。如果使用 var,最后输出的是10。

3、不存在变量提升

var命令会存在“变量提升”现象,即变量可以在声明之前使用,值为undefined。这种现象会让人觉得很奇怪,按照一般的逻辑,变量应该在声明语句之后才可以使用。

那么为了纠正(避免)这种现象,let命令改变了语法行为,它所声明的变量一定要在声明后使用,否则会报错。

// var 的情况
console.log(foo); // 输出undefined
var foo = 2;

// let 的情况
console.log(bar); // 报错ReferenceError
let bar = 2;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值