函数柯里化是将多参函数转为单参函数链,通过闭包逐步收参、延迟执行;函数组合则串联单参函数,让数据从右向左流动。二者结合可提升代码复用性、可测试性与表达力。

函数柯里化和函数组合是函数式编程中的两个核心技巧,它们能让 JavaScript 代码更灵活、可复用、易测试。
怎样手动实现函数柯里化?
柯里化是把一个接收多个参数的函数,转换为一系列只接收一个参数的函数的过程。关键在于“逐步收参、延迟执行”。
- 基础写法:用闭包保存已传入的参数,直到参数数量足够才真正调用原函数
- 通用柯里化函数支持任意参数个数,通常通过 length 属性判断形参个数
- 注意:箭头函数没有 arguments 和 length(绑定到外层),需用普通函数
示例:
function curry(fn) {return function curried(...args) {
if (args.length >= fn.length) {
return fn.apply(this, args);
} else {
return function(...moreArgs) {
return curried.apply(this, args.concat(moreArgs));
};
}
};
}
如何用柯里化提升实用性?
不是为了炫技,而是解决真实问题:固定部分参数,生成专用函数。
立即学习“Java免费学习笔记(深入)”;
- 比如 add = (a, b) => a + b,柯里化后 add10 = curry(add)(10),再调用 add10(5) 得到 15
- 处理事件处理器时,预设配置或 ID:handleClick = curry(updateItem)(userId)
- 与数组方法配合:[1,2,3].map(curry(Math.pow)(2)) → 平方数组
函数组合的基本技巧
组合(compose)是把多个单参函数串起来,让数据从右向左流过每个函数,即 f(g(h(x))) 等价于 compose(f, g, h)(x)。
- 最简实现:const compose = (...fns) => x => fns.reduceRight((acc, f) => f(acc), x)
- 推荐从右到左(数学惯例),也有人习惯 pipe(从左到右),本质一致,选一种并保持统一
- 组合函数必须是纯函数、单参数;多参数函数需先柯里化再组合
例子:
const toUpper = s => s.toUpperCase();const exclaim = s => s + '!';
const shout = compose(exclaim, toUpper);
shout('hello'); // 'HELLO!'
柯里化 + 组合 = 更强表达力
两者常一起用:先柯里化获得可组合的单元,再用组合构建逻辑流水线。
- 如处理用户数据:const getActiveNames = compose(map(get('name')), filter(get('active')), get('users')),其中 get = curry((k, obj) => obj[k])
- 避免中间变量,逻辑一目了然;每个小函数职责单一,便于复用和测试
- 注意调试:组合链过长时,可用带日志的中间函数临时插入观察
基本上就这些。不复杂但容易忽略——关键是理解“拆分”和“连接”的思想,而不是死记语法。











