柯里化是将多参数函数转换为单参数函数链的过程,通过闭包保存已传参数,待参数数量满足时执行原函数;其核心是延迟求值与部分参数固定,区别于可多参数传入的偏函数。

柯里化(Currying)是把一个接收多个参数的函数,转换成一系列只接收一个参数的函数的过程。每次调用返回一个新的函数,直到所有参数都传齐,才执行原函数并返回结果。
核心思想:参数分步传递
它不改变函数逻辑,只是调整调用方式——把 f(a, b, c) 变成 f(a)(b)(c)。关键在于“延迟求值”和“固定部分参数”。
- 每一步只接收一个参数,返回一个新函数等待下一个
- 内部通过闭包保存已传入的参数
- 当参数数量满足原函数要求时,触发实际执行
手动实现一个通用柯里化函数
可以用 Function.prototype.length 获取原函数期望的参数个数,再递归收集参数:
function curry(fn) {
return function curried(...args) {
if (args.length >= fn.length) {
return fn.apply(this, args);
} else {
return function(...nextArgs) {
return curried.apply(this, args.concat(nextArgs));
};
}
};
}
例如:
立即学习“Java免费学习笔记(深入)”;
const add = (a, b, c) => a + b + c; const curriedAdd = curry(add); console.log(curriedAdd(1)(2)(3)); // 6 console.log(curriedAdd(1, 2)(3)); // 6 console.log(curriedAdd(1)(2, 3)); // 6
柯里化 vs 偏函数(Partial Application)
两者常被混淆,但有区别:
- 柯里化严格按“一次一个参数”,必须逐步调用,最终才执行
- 偏函数可一次传多个,也可传少于预期的参数,返回的新函数仍可接受剩余参数(不要求单参数链式)
- 柯里化是偏函数的一种特殊形式,但偏函数更灵活、更贴近实际使用
实际用途:提升复用与组合能力
柯里化本身不是为炫技,而是让函数更容易定制和组合:
- 创建专用函数:比如
const getUserName = curry(getProp)('name') - 配合函数式工具(如 Ramda、Lodash 的
curry)做数据处理管道 - 在 React 中预置 props 或事件处理器:
onClick={curriedHandleClick(id)}
基本上就这些。它不复杂,但容易忽略闭包和参数长度判断这两个关键点。











