0

0

JavaScript中的变量提升是什么_let和const如何避免

狼影

狼影

发布时间:2025-12-31 23:07:02

|

714人浏览过

|

来源于php中文网

原创

javascript中的变量提升是什么_let和const如何避免

变量提升(Hoisting)到底发生了什么

JavaScript 在执行前会先进行“预解析”,把 var 声明的变量和 function 声明提升到作用域顶部,但只有声明被提升,赋值不会。这意味着你可以“在声明前使用” var 变量,但它值是 undefined,而不是报错。

典型错误现象:

console.log(a); // undefined<br>var a = 1;
看起来像变量“提前存在”,其实是声明被挪到了作用域开头,等价于:
var a;<br>console.log(a); // undefined<br>a = 1;

letconst 不提升?其实是“暂时性死区”(TDZ)

letconst 声明**也会被提升**,但不初始化,且在声明语句执行前访问它们会直接抛出 ReferenceError。这个不可访问的区间就是“暂时性死区”。

常见错误场景:

console.log(b); // ReferenceError: Cannot access 'b' before initialization<br>let b = 2;
注意:不是 undefined,而是明确报错 —— 这是刻意设计的保护机制。

立即学习Java免费学习笔记(深入)”;

WPS灵犀
WPS灵犀

WPS灵犀是WPS推出的一款AI智能办公和学习助手

下载
  • letconst 的 TDZ 从块级作用域(如 {}iffor)顶部开始,直到声明语句执行
  • 函数参数也受 TDZ 影响:function foo(a = b, b) { } 会报错,因为 a 默认值中引用了尚未初始化的 b
  • typeof 对未声明变量返回 "undefined",但对 TDZ 中的 let 变量仍会报错:typeof xxlet x 但还没声明)→ ReferenceError

为什么 let/const 能“避免”提升带来的问题

它们没避开提升本身,而是用 TDZ 把隐式错误显性化。相比 var 的静默 undefinedlet/const 强制你按顺序写代码,减少因变量位置疏忽导致的逻辑 bug。

实际影响:

if (false) {<br>  let x = 1;<br>}<br>console.log(x); // ReferenceError —— 块外根本访问不到<br>// 而 var x 在这里会是 undefined(甚至可能意外污染外层)

  • 块级作用域 + TDZ 让作用域边界更清晰,避免循环中闭包捕获错误值(比如 for (var i=0; i console.log(i)) 全输出 3;用 let i 就输出 0/1/2
  • const 还额外禁止重新赋值,进一步缩小出错面(注意:它只保证绑定不改变,对象属性仍可修改)
  • ESLint 规则如 no-use-before-definevar 效果有限,但对 let/const 的 TDZ 报错天然免疫 —— 错误在运行时就暴露了

容易被忽略的细节:函数声明 vs 函数表达式

函数声明会被完全提升(声明 + 定义),但函数表达式不会:

foo(); // OK<br>function foo() {}<br><br>bar(); // TypeError: bar is not a function<br>var bar = function() {};
而用 let bar = function() {} 则是 ReferenceError(TDZ)。

更隐蔽的是:箭头函数、class 声明都遵循 let 规则 —— 全部有 TDZ。

console.log(Cat); // ReferenceError<br>class Cat {}

真正要注意的不是“有没有提升”,而是“能不能安全访问”。只要记住:遇到 letconst,就默认它前面那部分区域是禁区,别跨过去读写。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
typedef和define区别
typedef和define区别

typedef和define区别在类型检查、作用范围、可读性、错误处理和内存占用等。本专题为大家提供typedef和define相关的文章、下载、课程内容,供大家免费下载体验。

118

2023.09.26

define的用法
define的用法

define用法:1、定义常量;2、定义函数宏:3、定义条件编译;4、定义多行宏。更多关于define的用法的内容,大家可以阅读本专题下的文章。

360

2023.10.11

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

839

2023.08.22

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

557

2023.09.20

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

768

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

24

2025.12.06

go语言闭包相关教程大全
go语言闭包相关教程大全

本专题整合了go语言闭包相关数据,阅读专题下面的文章了解更多相关内容。

151

2025.07.29

console接口是干嘛的
console接口是干嘛的

console接口是一种用于在计算机命令行或浏览器开发工具中输出信息的工具,提供了一种简单的方式来记录和查看应用程序的输出结果和调试信息。本专题为大家提供console接口相关的各种文章、以及下载和课程。

419

2023.08.08

AI安装教程大全
AI安装教程大全

2026最全AI工具安装教程专题:包含各版本AI绘图、AI视频、智能办公软件的本地化部署手册。全篇零基础友好,附带最新模型下载地址、一键安装脚本及常见报错修复方案。每日更新,收藏这一篇就够了,让AI安装不再报错!

0

2026.03.04

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 5.7万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.3万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号