0

0

javascript函数有哪些类型_它们之间有什么区别?

狼影

狼影

发布时间:2026-01-02 22:43:02

|

275人浏览过

|

来源于php中文网

原创

javascript函数按定义和行为分为四类:函数声明(完全提升、有名字)、函数表达式(仅变量名提升、可匿名)、箭头函数(无this/arguments/new.target)、生成器函数(function* + yield)。

javascript函数有哪些类型_它们之间有什么区别?

JavaScript 函数不是一种“类型”,而是一种可调用的对象(Function 类型);但按定义方式、行为特征和运行时表现,确实存在几类常见函数形态——它们的区别直接影响 this 绑定、提升行为、作用域、是否可构造等关键行为。


函数声明 vs 函数表达式:提升(hoisting)是最大分水岭

函数声明会被完整提升到当前作用域顶部,可在定义前安全调用;函数表达式只提升变量名(var 声明),赋值本身不提升,提前调用会报 TypeError: xxx is not a function

console.log(add(2, 3)); // ✅ 输出 5  
function add(a, b) { return a + b; }
<p>console.log(sub(2, 3)); // ❌ TypeError: sub is not a function<br />
const sub = function(a, b) { return a - b; };
  • 函数声明必须有名字,且不能出现在条件块、循环体等非顶层语句中(严格模式下会报语法错误)
  • 函数表达式可匿名,也可命名(命名仅在函数体内可用,用于调试或递归)
  • 函数表达式更灵活:能作为参数传入、返回值、立即执行(IIFE)、赋给对象属性

箭头函数:没有自己的 this,也没有 argumentsnew.target

箭头函数不绑定 this,而是继承外层普通函数作用域的 this;它不能用作构造函数(调用 new 会抛 TypeError),也不支持 arguments 对象(需用剩余参数 ...args 替代)。

const obj = {
  name: 'Alice',
  regular() { console.log(this.name); }, // ✅ 'Alice'
  arrow: () => { console.log(this.name); } // ❌ undefined(this 指向全局或 module 上下文)
};
<p>obj.regular(); // 'Alice'<br />
obj.arrow();   // undefined(浏览器中 this 是 window)
  • 适合写简短回调(如 array.map(x => x * 2)),避免手动 .bind(this)
  • 不适合需要动态 this 的场景(如事件处理器、Vue/React 方法、原型方法)
  • 不能用 yield,所以不能是生成器函数

生成器函数:function* 返回迭代器,支持暂停与恢复

生成器函数用 function* 声明,内部用 yield 暂停执行并产出值;调用后不立即运行,而是返回一个迭代器对象,需用 .next() 手动推进。

Text-To-Song
Text-To-Song

免费的实时语音转换器和调制器

下载

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

function* countdown(n) {
  while (n > 0) {
    yield n;
    n--;
  }
}
<p>const it = countdown(3);
console.log(it.next().value); // 3<br />
console.log(it.next().value); // 2<br />
console.log(it.next().value); // 1
  • 常用于实现惰性求值、自定义遍历逻辑、异步流程控制(配合 async/await 模拟)
  • 不能被 new 调用,也不是普通函数的子类型
  • 不兼容 IE,且 V8 引擎对生成器的优化弱于普通函数,高频调用注意性能

构造函数与普通函数:只差一个 new,行为天壤之别

构造函数本质仍是函数,但约定以大写字母开头,并预期通过 new 调用;此时会自动创建新对象、绑定 this、隐式返回该对象(除非显式返回非空对象)。

function Person(name) {
  this.name = name;
}
<p>const p = new Person('Bob'); // ✅ this 指向新对象<br />
const q = Person('Charlie'); // ❌ this 指向全局(非严格模式)或 undefined(严格模式)
  • 不加 new 调用构造函数,极大概率造成意外的全局污染或 undefined 属性赋值
  • 现代推荐用 class 语法替代传统构造函数,更明确意图且自带 new 检查(class 构造器不可直接调用)
  • Function 构造器(new Function('a', 'b', 'return a+b'))应避免使用——无法访问闭包、存在安全与性能隐患

函数类型之间的边界有时很模糊(比如箭头函数也是函数表达式的一种),真正重要的是你在什么上下文中怎么用它。最容易被忽略的,其实是提升规则和 this 绑定这两点——它们往往不会立刻报错,却会在重构或移动代码时突然暴露问题。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

850

2024.01.03

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

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

30

2025.12.06

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

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

151

2025.07.29

golang map内存释放
golang map内存释放

本专题整合了golang map内存相关教程,阅读专题下面的文章了解更多相关内容。

77

2025.09.05

golang map相关教程
golang map相关教程

本专题整合了golang map相关教程,阅读专题下面的文章了解更多详细内容。

40

2025.11.16

golang map原理
golang map原理

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

67

2025.11.17

java判断map相关教程
java判断map相关教程

本专题整合了java判断map相关教程,阅读专题下面的文章了解更多详细内容。

47

2025.11.27

undefined是什么
undefined是什么

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

6466

2023.07.31

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

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

精品课程

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

共42课时 | 9.4万人学习

Vue3.x 工具篇--十天技能课堂
Vue3.x 工具篇--十天技能课堂

共26课时 | 1.6万人学习

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

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