let 和 const 命令

本文介绍了JavaScript中let和const的关键特性,包括块级作用域、循环中的变量行为、变量提升、暂时性死区以及它们与var的区别,强调了const的不可重复声明和初始化要求。
摘要由CSDN通过智能技术生成

let 的特点

  • 块级作用域
{
  let i = 1;
}
console.log(i); // ReferenceError: i is not defined

let 在循环中定义变量时,只在本轮循环有效,每一次循环都是一个新的变量,而 var 在循环中定义变量时,变量的作用域是整个循环,所以会覆盖前面的变量。

let 在循环中定义变量时,JavaScript 引擎会记住上一轮循环的值,初始化本轮的变量时,会在上一轮循环的基础上进行计算。

ES6 的块级作用域必须有大括号,如果没有大括号,JavaScript 引擎就认为不存在块级作用域。

if(true) let i = 1; // SyntaxError: Lexical declaration cannot appear in a single-statement context
  • 不允许重复声明
var i = 1;
let i = 2; // SyntaxError: Identifier 'i' has already been declared
  • 没有变量提升
console.log(i); // ReferenceError: Cannot access 'i' before initialization
let i = 1;
  • 暂时性死区
let i = 1;
{
  console.log(i); // ReferenceError: Cannot access 'i' before initialization
  let i = 2;
}

因为暂时性死区的存在,typeof 操作也不再安全。

typeof i; // ReferenceError: Cannot access 'i' before initialization
let i = 1;
  • 不存在于顶层对象
let i = 1;
console.log(window.i); // undefined

var 和 function 声明的全局变量,依旧是顶层对象的属性。

let 、const 、class 声明的全局变量,不属于顶层对象的属性。

const 的特点

  • const 不能重复声明,也不能修改。
const i = 1;
i = 2; // TypeError: Assignment to constant variable.

const 一旦声明变量,就必须立即初始化,不能留到以后赋值。

  • const 其他特点和 let 基本一样。
  • 6
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值