0

0

javascript中什么是高阶函数_它有哪些常见例子【教程】

幻影之瞳

幻影之瞳

发布时间:2026-01-29 16:21:09

|

932人浏览过

|

来源于php中文网

原创

高阶函数是接受函数作为参数或返回函数作为结果的函数。如map、filter、reduce、setTimeout、Promise.then等内置方法,以及自定义的logAfter、createMultiplier和addEventListener均属此类,体现函数作为值传递与延迟执行特性。

javascript中什么是高阶函数_它有哪些常见例子【教程】

高阶函数不是“高级”的函数,而是指**接受函数作为参数、或返回函数作为结果**的函数。这是 JavaScript 函数式编程的基础特征,不是语法糖,而是语言原生支持的能力。

哪些内置函数是典型的高阶函数

JavaScript 运行时自带多个高频使用的高阶函数,它们都接收 callback回调函数)作为参数:

  • Array.prototype.map():对每个元素调用传入的函数,返回新数组
  • Array.prototype.filter():用传入函数判断真假,保留为 true 的元素
  • Array.prototype.reduce():用传入的累加器函数合并所有元素
  • setTimeout()setInterval():第一个参数必须是函数
  • Promise.then()Promise.catch():接收处理函数,不是值

注意:forEach() 也是,但它不返回新数组,所以不适合链式调用;而 map()filter() 返回新数组,天然适合组合使用。

自己写的函数怎么变成高阶函数

只要函数签名里出现函数类型的参数,或者 return 一个函数,它就是高阶函数。常见写法有两类:

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

QIMI奇觅
QIMI奇觅

美图推出的游戏行业广告AI制作与投放一体化平台

下载
  • 接收函数作为参数:function logAfter(fn) { return function(...args) { console.log('run'); return fn(...args); }; }
  • 返回函数(即“函数工厂”):function createMultiplier(n) { return function(x) { return x * n; }; },调用 createMultiplier(3)(4) 得到 12

这类写法常用于封装逻辑复用,比如权限校验、日志埋点、防抖节流——但要注意闭包中变量的生命周期,避免意外持有大对象。

为什么 addEventListener 是高阶函数但容易被忽略

因为它的第二个参数明确要求是 EventListener 类型(即函数),而且这个函数会在未来某个事件触发时被调用。它典型体现了“函数作为值传递 + 延迟执行”的高阶特性:

  • 你传进去的不是执行结果,而是“将来要怎么处理”的定义
  • 这个函数可以访问定义时的作用域(闭包),比如 let id = 1; btn.addEventListener('click', () => console.log(id))
  • 如果传的是箭头函数且依赖外部变量,又在循环中注册,容易因变量提升导致所有监听器共享最后一个值——这是最常见的坑

真正难的不是写出高阶函数,而是判断何时该把逻辑抽成函数传入,何时该提前执行;更关键的是,理解函数被传入后,它的 this、作用域和调用时机是否符合预期。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
php中foreach用法
php中foreach用法

本专题整合了php中foreach用法的相关介绍,阅读专题下面的文章了解更多详细教程。

75

2025.12.04

java值传递和引用传递有什么区别
java值传递和引用传递有什么区别

java值传递和引用传递的区别:1、基本数据类型的传递;2、对象的传递;3、修改引用指向的情况。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

108

2024.02.23

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

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

137

2025.07.29

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

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

75

2025.09.05

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

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

36

2025.11.16

golang map原理
golang map原理

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

60

2025.11.17

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

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

42

2025.11.27

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

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

415

2023.08.08

clawdbot ai使用教程 保姆级clawdbot部署安装手册
clawdbot ai使用教程 保姆级clawdbot部署安装手册

Clawdbot是一个“有灵魂”的AI助手,可以帮用户清空收件箱、发送电子邮件、管理日历、办理航班值机等等,并且可以接入用户常用的任何聊天APP,所有的操作均可通过WhatsApp、Telegram等平台完成,用户只需通过对话,就能操控设备自动执行各类任务。

13

2026.01.29

热门下载

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

精品课程

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

共58课时 | 4.3万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.5万人学习

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号