【前端面经】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

相关推荐
浅念-几秒前
C++ 继承
开发语言·c++·经验分享·笔记·学习·算法·继承
yuki_uix3 分钟前
为什么我的 Auth Token 藏在了 Network 面板的 Doc 里?
前端·python·debug
不会敲代码15 分钟前
从原子CSS到TailwindCSS:现代前端样式解决方案全解析
前端·css·react.js
Wect9 分钟前
LeetCode 102. 二叉树的层序遍历:图文拆解+代码详解
前端·算法·typescript
简离10 分钟前
VSCode Git Bash 终端:告别内置vi,直接用VSCode编辑交互内容
前端
新缸中之脑25 分钟前
Sonnet 4.6 vs Opus 4.6
java·开发语言
曹牧27 分钟前
Java:@RequestBody 和 @RequestParam混合使用
java·开发语言
冴羽38 分钟前
2026 年 JavaScript 框架 3 大趋势
前端·javascript·react.js
思茂信息1 小时前
基于CST 3D Combined功能的以太网口RE仿真
开发语言·javascript·单片机·嵌入式硬件·matlab·3d
一枚前端小姐姐1 小时前
Vue3 组合式 API(setup + script setup)实战
前端·vue.js