0

0

JavaScript中的变量提升与暂时性死区_javascript核心

狼影

狼影

发布时间:2025-11-05 19:07:02

|

240人浏览过

|

来源于php中文网

原创

变量提升将var和函数声明移至作用域顶部,而let和const存在暂时性死区,禁止在声明前访问。1. var声明提升且初始化为undefined;2. let/const提升但未初始化,访问触发referenceerror;3. 函数声明完全提升,可提前调用;4. 函数表达式表现取决于赋值方式;5. 建议先声明后使用,优先采用let和const以避免意外行为。

javascript中的变量提升与暂时性死区_javascript核心

JavaScript中的变量提升和暂时性死区是理解变量生命周期的关键概念。很多人在使用varletconst时会遇到意料之外的行为,根源往往就出在这两个机制上。

变量提升(Hoisting)

JavaScript引擎在执行代码之前会先进行编译阶段,这个阶段会将变量和函数的声明“提升”到作用域的顶部。

对于var声明的变量,其声明会被提升,但赋值不会。

console.log(name); // 输出:undefined

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

var name = "Alice";

// 相当于:

var name;

console.log(name); // undefined

name = "Alice";

函数声明也会被完整提升,可以在声明前调用。

sayHello(); // 输出:Hello!

function sayHello() {

  console.log("Hello!");

}

let 和 const 的暂时性死区(Temporal Dead Zone, TDZ)

letconst虽然也会被提升,但在进入作用域后到正式声明之前,处于“暂时性死区”——此时访问变量会抛出错误。

ChatMind
ChatMind

ChatMind是一款AI生成思维导图的效率工具,可以通过AI对话生成和编辑思维导图。

下载

console.log(age); // 报错:ReferenceError

let age = 25;

这是因为letconst的设计初衷是避免var带来的误解。在声明前访问它们是不被允许的。

TNZ从作用域开始到变量声明完成前都存在。例如:

function example() {

  console.log(value); // ReferenceError

  let value = 10;

}

var、let、const 的行为对比

不同关键字在提升和死区上的表现有明显区别:

  • var:声明提升,初始化为undefined,无TDZ
  • let:声明提升,但未初始化,存在TDZ
  • const:同let,且必须在声明时赋值

函数表达式的行为取决于声明方式:

console.log(funcVar); // undefined(可调用?不,它是undefined)

funcVar(); // TypeError: funcVar is not a function

var funcVar = function() { console.log("Hi"); };

实际开发建议

为了避免因提升和TDZ导致的问题,推荐以下做法:

  • 始终在使用变量前声明它们
  • 优先使用letconst代替var
  • 理解块级作用域的影响,尤其是letconstiffor中的行为
  • 避免在声明前访问变量,即使语法上看似“合法”

基本上就这些。掌握变量提升和暂时性死区,能帮助你写出更 predictable 的JavaScript代码。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
if什么意思
if什么意思

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

846

2023.08.22

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

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

561

2023.09.20

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

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

420

2023.08.08

console.log是什么
console.log是什么

console.log 是 javascript 函数,用于在浏览器控制台中输出信息,便于调试和故障排除。想了解更多console.log的相关内容,可以阅读本专题下面的文章。

541

2024.05.29

undefined是什么
undefined是什么

undefined是代表一个值或变量不存在或未定义的状态。它可以作为默认值来判断一个变量是否已经被赋值,也可以用于设置默认参数值。尽管在不同的编程语言中,undefined可能具有不同的含义和用法,但理解undefined的概念可以帮助我们更好地理解和编写程序。本专题为大家提供undefined相关的各种文章、以及下载和课程。

6438

2023.07.31

网页undefined是什么意思
网页undefined是什么意思

网页undefined是指页面出现了未知错误的意思,提示undefined一般是在开发网站的时候定义不正确或是转换不正确,或是找不到定义才会提示undefined未定义这个错误。想了解更多的相关内容,可以阅读本专题下面的文章。

3328

2024.08.14

网页undefined啥意思
网页undefined啥意思

本专题整合了undefined相关内容,阅读下面的文章了解更多详细内容。后续继续更新。

1639

2025.12.25

function是什么
function是什么

function是函数的意思,是一段具有特定功能的可重复使用的代码块,是程序的基本组成单元之一,可以接受输入参数,执行特定的操作,并返回结果。本专题为大家提供function是什么的相关的文章、下载、课程内容,供大家免费下载体验。

498

2023.08.04

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

4

2026.03.10

热门下载

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

精品课程

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

共58课时 | 5.9万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.4万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

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

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