首页 > web前端 > js教程 > 正文

什么是高阶函数_javascript中函数作为参数如何传递?

夢幻星辰
发布: 2025-12-14 20:01:41
原创
551人浏览过
高阶函数是接收函数作为参数或返回函数的函数,体现函数作为一等公民;典型形式有map/filter/reduce(传函数)和防抖/柯里化(返回函数),传参时需注意fn与fn()的区别。

什么是高阶函数_javascript中函数作为参数如何传递?

高阶函数就是把函数当作参数传进去,或者返回一个函数的函数。核心就两点:函数可以像数字、字符串一样被传递和使用;JavaScript 中函数是一等公民。

高阶函数的两种典型形式

一种是接收函数作为参数,比如 mapfilterreduce;另一种是返回函数,比如防抖(debounce)、柯里化(curry)函数。

  • 接收函数:传进去的是“做什么”,不是“做多少次”或“对谁做”,而是“怎么处理”
  • 返回函数:生成一个新函数,常用于配置复用或延迟执行

函数作为参数怎么传?不加括号才是传函数本身

关键细节:写 fn 是传函数引用,写 fn() 是立即执行并传它的返回值。

  • ✅ 正确:arr.map(handleItem) —— 把 handleItem 这个函数交给 map 内部去调用
  • ❌ 错误:arr.map(handleItem()) —— 先执行 handleItem(),把它的返回值(比如 undefined)传给 map,会报错
  • 需要传参时用箭头函数包装:arr.map(item => doSomething(item, extra))

自己写一个接收函数的高阶函数

理解原理最直接的方式是手写一个简化版的 filter:

Musho
Musho

AI网页设计Figma插件

Musho 76
查看详情 Musho

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

function myFilter(arr, predicate) {
  const result = [];
  for (let i = 0; i < arr.length; i++) {
    if (predicate(arr[i])) { // 这里调用传入的函数
      result.push(arr[i]);
    }
  }
  return result;
}

// 使用:
const numbers = [1, 2, 3, 4];
const evens = myFilter(numbers, n => n % 2 === 0); // 传入一个判断逻辑
// evens 是 [2, 4]
登录后复制

你看,predicate 就是那个“判断规则”,它由调用者决定,myFilter 只负责流程控制。

基本上就这些。不复杂但容易忽略括号和执行时机,多写两次就能形成直觉。

以上就是什么是高阶函数_javascript中函数作为参数如何传递?的详细内容,更多请关注php中文网其它相关文章!

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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