0

0

JavaScript函数名提升现象与匿名函数表达式的限制

舞夢輝影

舞夢輝影

发布时间:2026-03-15 20:19:31

|

669人浏览过

|

来源于php中文网

原创

函数声明会被完整提升,而匿名函数表达式仅变量声明被提升、赋值和函数体不提升;var声明的表达式调用报TypeError,let/const则抛ReferenceError。

javascript函数名提升现象与匿名函数表达式的限制

函数声明会被提升(hoisting),但匿名函数表达式不会——这是理解JavaScript执行上下文和变量生命周期的关键区别。

函数声明会完整提升

当使用 function 关键字直接定义函数(即函数声明)时,整个函数定义会在代码执行前被“提升”到当前作用域顶部,包括函数名和函数体。这意味着你可以在声明之前调用它:

console.log(add(2, 3)); // 5  
function add(a, b) {  
  return a + b;  
}

这段代码能正常运行,因为 add 函数在进入执行阶段前已被解析并绑定到作用域中。

匿名函数表达式只提升变量名,不提升赋值

当把函数写成赋值形式(如 const fn = function() {...}var fn = function() {...}),本质是“变量声明 + 函数创建 + 赋值”三步。只有 变量声明部分会被提升,而函数本身和赋值操作仍保留在原位置:

B12
B12

B12是一个由AI驱动的一体化网站建设平台

下载

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

console.log(fn()); // TypeError: fn is not a function  
var fn = function() {  
  return "hello";  
};
  • 使用 var:变量名 fn 被提升,初始值为 undefined;调用时实际执行的是 undefined(),报错
  • 使用 letconst:变量声明仍被提升,但处于“暂时性死区”(TDZ),在声明前访问会直接抛出 ReferenceError

箭头函数和命名函数表达式也遵循表达式规则

箭头函数(const fn = () => {})和命名函数表达式(const fn = function named() {})都属于函数表达式范畴,同样不会被提升函数体

  • 它们的标识符(如 fn)是否可提前访问,取决于声明方式(var / let / const
  • 函数名 named 在函数体内可用(用于递归等),但在外部不可访问,也不参与提升

如何避免因提升差异导致的错误

推荐采用一致、可预测的函数定义方式:

  • 优先使用 const 声明函数表达式,明确表达“不可重新赋值”的意图
  • 需要提升行为时,用函数声明;否则统一放在调用点之后,或确保声明在使用前完成
  • 现代开发中,借助 ESLint 规则(如 no-use-before-define)主动拦截提前使用
  • 模块级顶层逻辑建议用 IIFE 或显式初始化函数,减少对提升机制的依赖

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

119

2023.09.26

define的用法
define的用法

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

391

2023.10.11

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

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

216

2023.12.04

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

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

326

2024.02.23

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

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

293

2025.06.11

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

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

179

2025.08.07

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

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

564

2023.09.20

undefined是什么
undefined是什么

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

6556

2023.07.31

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

69

2026.03.13

热门下载

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

精品课程

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

共58课时 | 6.1万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.5万人学习

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号