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

相关推荐
枫叶丹42 分钟前
【HarmonyOS 6.0】MDM Kit:PC/2in1设备用户行为限制策略详解
开发语言·华为·harmonyos
weilaieqi14 分钟前
微短剧 + 时代到来,短剧内容正在赋能文旅、品牌与数字文化产业
开发语言
888CC++7 分钟前
箭头函数(ES6)
前端·javascript·es6
ytttr87312 分钟前
航天器姿态控制 MATLAB 仿真程序
开发语言·matlab
charlie11451419113 分钟前
嵌入式Linux驱动开发——从轮询到中断
linux·开发语言·驱动开发·嵌入式
qq_4198540516 分钟前
css filter
前端·javascript·css
放弃 治疗18 分钟前
宝塔面板安装 JDK 完整教程|Java 环境配置详解
java·开发语言
工头阿乐21 分钟前
使用Conan构建现代C++项目:完整指南
开发语言·c++
Agatha方艺璇35 分钟前
VUE复习笔记
前端·vue.js
大家的林语冰1 小时前
npm 不忍了,正式上线“阶段式发布“的新功能,进一步对抗频繁的供应链攻击!
前端·javascript·node.js