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

相关推荐
程序喵大人1 小时前
推荐个C++高性能内存分配器
开发语言·c++·内存分配
liu****1 小时前
27.epoll(三)
服务器·开发语言·网络·tcp/ip·udp
福尔摩斯张1 小时前
Axios源码深度解析:前端请求库设计精髓
c语言·开发语言·前端·数据结构·游戏·排序算法
aiguangyuan1 小时前
React 中什么是可中断更新?
javascript·react·前端开发
zephyr051 小时前
深入浅出C++多态:从虚函数到动态绑定的完全指南
开发语言·c++
Chef_Chen1 小时前
数据科学每日总结--Day25--区块链
开发语言·php
L-李俊漩1 小时前
MMN-MnnLlmChat 启动顺序解析
开发语言·python·mnn
小镇学者1 小时前
【PHP】PHP WebShell(网页木马)分析
android·开发语言·php
q***69771 小时前
java进阶1——JVM
java·开发语言·jvm