0

0

如何编写javascript函数_函数声明与表达式有何不同【教程】

夢幻星辰

夢幻星辰

发布时间:2026-01-30 15:04:03

|

502人浏览过

|

来源于php中文网

原创

函数声明会被提升,函数表达式不会;前者可在声明前调用,后者则报错;块级函数声明在严格模式下仅限块内有效,建议统一用函数表达式确保兼容性。

如何编写javascript函数_函数声明与表达式有何不同【教程】

函数声明和函数表达式在执行时机、作用域行为和可调用性上根本不同,不是写法偏好问题,而是会影响代码是否报错、何时能用。

函数声明会被提升(hoisting),函数表达式不会

JavaScript 引擎在执行前会先处理所有 function 声明语句,并把函数名和定义一起“提升”到当前作用域顶部。所以你能在声明前就调用它:

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

但函数表达式只是变量赋值,只有变量声明(var)会被提升,赋值不会:

console.log(multiply(2, 3)); // TypeError: multiply is not a function
var multiply = function(a, b) {
  return a * b;
};
  • 如果用 letconst 声明函数表达式,连变量声明都不会提升,直接报 ReferenceError
  • 箭头函数本质也是函数表达式,同样不提升
  • 提升只发生在函数声明(function name() {...}),不包括命名函数表达式(var f = function name() {...}

命名函数表达式有名字,但名字只在函数内部可用

给函数表达式加名字(比如 var f = function foo() {...})不是为了外部调用,而是用于调试和递归:

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

腾讯云AI代码助手
腾讯云AI代码助手

基于混元代码大模型的AI辅助编码工具

下载
var factorial = function fact(n) {
  return n <= 1 ? 1 : n * fact(n - 1);
};
console.log(factorial(5)); // 120
console.log(fact(5));      // ReferenceError: fact is not defined
  • 函数名 fact 在外部作用域不可访问,只存在于函数自身作用域内
  • Chrome 和 Firefox 的开发者工具会用这个名称显示调用栈,比 anonymous 更易排查
  • 不命名的函数表达式(function() {...})在堆栈里显示为 anonymous 或空字符串

函数声明必须有名字,函数表达式可以匿名

function 关键字后紧跟标识符是语法强制要求 —— 函数声明不能匿名:

function () { } // SyntaxError: Function statements must have a name

而函数表达式作为值,可以没有名字:

var handler = function() { console.log('clicked'); };
button.addEventListener('click', handler);
  • 事件回调、定时器、Promise 回调等场景中,匿名函数表达式更简洁
  • 但若需调试或递归,应优先用命名函数表达式
  • ES6+ 中,const fn = () => {} 是带词法作用域的函数表达式,也必须匿名(箭头函数无 name 属性)

严格模式下,函数声明在块级作用域中的行为不一致

在非严格模式中,函数声明出现在 if{} 块内时,部分引擎(如旧版 Chrome)会将其提升到函数作用域顶层,但这是非标准行为;严格模式下,块级函数声明被规范为仅在该块内有效:

'use strict';
if (true) {
  function inside() { return 'ok'; }
}
inside(); // ReferenceError in strict mode
  • 这种差异导致跨浏览器兼容性风险,建议避免在块内写函数声明
  • 如需条件定义函数,统一用函数表达式 + 变量赋值(let/const)更可靠
  • Node.js v14+ 和现代浏览器对块级函数声明支持较一致,但仍建议以表达式为准

真正容易出问题的地方,往往不是“怎么写”,而是“什么时候能用”——提升规则、块级作用域限制、调试信息缺失,这些细节在重构或调试异步链时才会突然暴露。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

839

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

744

2023.11.06

es6新特性
es6新特性

es6新特性有:1、块级作用域变量;2、箭头函数;3、模板字符串;4、解构赋值;5、默认参数;6、 扩展运算符;7、 类和继承;8、Promise。本专题为大家提供es6新特性的相关的文章、下载、课程内容,供大家免费下载体验。

106

2023.07.17

es6新特性有哪些
es6新特性有哪些

es6的新特性有:1、块级作用域;2、箭头函数;3、解构赋值;4、默认参数;5、扩展运算符;6、模板字符串;7、类和模块;8、迭代器和生成器;9、Promise对象;10、模块化导入和导出等等。本专题为大家提供es6新特性的相关的文章、下载、课程内容,供大家免费下载体验。

195

2023.08.04

JavaScript ES6新特性
JavaScript ES6新特性

ES6是JavaScript的根本性升级,引入let/const实现块级作用域、箭头函数解决this绑定问题、解构赋值与模板字符串简化数据处理、对象简写与模块化提升代码可读性与组织性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

222

2025.12.24

if什么意思
if什么意思

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

779

2023.08.22

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

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

183

2023.12.04

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

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

287

2024.02.23

C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

9

2026.01.30

热门下载

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

精品课程

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

共58课时 | 4.4万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.6万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.1万人学习

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

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