0

0

JavaScript中的变量提升是什么_它如何影响代码

幻影之瞳

幻影之瞳

发布时间:2025-12-26 21:00:50

|

331人浏览过

|

来源于php中文网

原创

变量提升指javascript引擎在编译阶段将var声明和函数声明提升至作用域顶部,但var只提升声明不提升赋值,函数声明则完全提升;let/const虽被提升但受暂时性死区限制,访问会报referenceerror。

javascript中的变量提升是什么_它如何影响代码

JavaScript中的变量提升(Hoisting)是指变量和函数声明在代码执行前被“移动”到其所在作用域顶部的现象。它不是字面意义上的物理移动,而是JavaScript引擎在编译阶段将声明部分提前处理的结果。理解它对避免意外的undefined、ReferenceError或逻辑错误至关重要。

变量提升只提升声明,不提升赋值

使用var声明的变量会被提升,但初始化(赋值)保留在原位置。这意味着你可以在声明前访问该变量,得到undefined,而不是报错。

例如:

console.log(a); // undefined<br>
var a = 10;<br>
console.log(a); // 10

实际等价于:

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

Deja Videos
Deja Videos

AI视频内容编辑工具

下载
var a;<br>
console.log(a); // undefined<br>
a = 10;<br>
console.log(a); // 10
  • 注意:只有var有这种“声明+初始化分离”的提升行为
  • letconst也会被提升,但它们处于“暂时性死区”(TDZ),在声明前访问会直接抛出ReferenceError

函数声明会被完全提升,函数表达式则不会

函数声明(function foo() {...})不仅声明被提升,整个函数体也一同提升,因此可在定义前调用。

foo(); // 正常输出 "hello"<br>
function foo() {<br>
  console.log("hello");<br>
}

但函数表达式(如用varletconst赋值的函数)只提升变量名,不提升赋值,因此调用会出错:

bar(); // TypeError: bar is not a function(var情况)或 ReferenceError(let/const)<br>
var bar = function() { console.log("world"); };
  • 函数声明优先级高于var变量声明,同名时函数声明会覆盖变量声明
  • 箭头函数属于函数表达式,同样不被完全提升

let/const 的提升与暂时性死区(TDZ)

letconst声明确实被提升,但在声明语句执行前,它们所绑定的标识符不可访问——这段区域就是暂时性死区。

console.log(b); // ReferenceError<br>
let b = 20;
  • TDZ从块级作用域开头开始,到声明语句执行完成为止
  • typeof对TDZ中的变量也不安全:typeof b同样抛错,不同于var下的"undefined"
  • 这有助于尽早发现未声明就使用的错误,增强代码健壮性

如何规避变量提升带来的问题

现代开发中,推荐通过以下方式减少相关陷阱:

  • 始终在作用域顶部声明变量(尤其是var),养成“先声明后使用”的习惯
  • 优先使用constlet替代var,利用TDZ获得更早的错误提示
  • 函数尽量使用函数声明(需被提前调用时),或确保函数表达式在调用前已赋值
  • 启用ESLint规则如no-use-before-define,自动检测潜在的提前使用问题

热门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

mysql标识符无效错误怎么解决
mysql标识符无效错误怎么解决

mysql标识符无效错误的解决办法:1、检查标识符是否被其他表或数据库使用;2、检查标识符是否包含特殊字符;3、使用引号包裹标识符;4、使用反引号包裹标识符;5、检查MySQL的配置文件等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

206

2023.12.04

Python标识符有哪些
Python标识符有哪些

Python标识符有变量标识符、函数标识符、类标识符、模块标识符、下划线开头的标识符、双下划线开头、双下划线结尾的标识符、整型标识符、浮点型标识符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

313

2024.02.23

java标识符合集
java标识符合集

本专题整合了java标识符相关内容,想了解更多详细内容,请阅读下面的文章。

290

2025.06.11

c++标识符介绍
c++标识符介绍

本专题整合了c++标识符相关内容,阅读专题下面的文章了解更多详细内容。

174

2025.08.07

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

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

557

2023.09.20

undefined是什么
undefined是什么

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

6101

2023.07.31

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

4

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号