【前端面经】JS 中 var、let、const 变量声明方式及其区别?

JS 中三种变量声明方式及其区别

三种变量声明方式及其区别

var、let、const 的对比

特性 var let const
函数作用域 √(变量在函数中声明时) not only not only
全局作用域 √(变量在函数外声明时) × ×
块级作用域 × √(变量声明的所在代码块) √(变量声明的所在代码块)
重新声明
重新赋值

const 的不可变性const 声明的变量必须初始化,且不能重新赋值。但是对于复杂数据类型(如对象),可以修改其中的内容。

变量的提升

  • var 的提升:变量被提升到作用域顶部并初始化;可以在声明之前访问 ,值为 undefined
  • let 的提升:变量被提升到作用域顶部但不初始化;不可以在声明之前访问 ,会报错 ReferenceError(称为暂时性死区,TDZ)
  • const 的提升:变量被提升到作用域顶部但不初始化;不可以在声明之前访问 ,会报错 ReferenceError(称为暂时性死区,TDZ)

暂时性死区的说明 :所谓暂时性死区,指的是在进入作用域直到变量声明被执行之前的这段时间内,变量是存在的但是无法被访问 ,任何访问都会导致 ReferenceError

相关推荐
神奇大叔4 分钟前
Java 配置文件记录
java·开发语言
AKclown10 分钟前
Vibe coding(AI编程一网打尽)
前端·react.js
埋塘小王子10 分钟前
React项目白屏兜底神器?ErrorBounary你了解吗?
前端
却尘17 分钟前
一个 ERR_SSL_PROTOCOL_ERROR 让我们排查了三层问题,最后发现根本不是 SSL 的锅
前端·后端·网络协议
三水彡彡彡彡18 分钟前
C++拷贝函数:const与引用的高效实践
开发语言·c++
用户830407130570118 分钟前
如何处理axios请求中post请求的坑
前端
行走在顶尖20 分钟前
vue3项目搭建基础
前端
sudo_明天上线20 分钟前
React 核心深度解析:调度、协调与提交的闭环全解
前端
广州华水科技26 分钟前
单北斗GNSS在变形监测中的应用与发展新趋势
前端
悠闲蜗牛�29 分钟前
深入浅出Spring Boot 3.x:新特性全解析与实战指南
开发语言·python