柯里化是将多参数函数转换为一系列单参数函数的技术,核心是分步固化参数并依赖闭包延迟执行,最终调用才求值。

JavaScript 柯里化(Currying)是一种将接收多个参数的函数,转换为一系列只接收一个参数的函数的技术。它的核心不是“省略参数”,而是“分步固化参数”,从而自然实现部分应用(Partial Application)——但要注意:柯里化是部分应用的一种严格形式,而部分应用不一定是柯里化。
柯里化的本质:参数拆解 + 闭包固化
一个柯里化函数每次只接受一个参数,返回一个新函数,直到接收完所有参数才真正执行原逻辑。它依赖闭包保存已传入的参数。
- 原始函数:
add(a, b, c) { return a + b + c; } - 柯里化后:
add(1)(2)(3) === 6,也可中途停在add(1)(2)得到一个等待c的函数 - 关键点:参数数量固定、调用链严格为单参数、最终调用才求值
手动实现一个通用柯里化函数
利用函数的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));
};
}
};
}
使用示例:
const add = (a, b, c) => a + b + c;
const curriedAdd = curry(add);
curriedAdd(1)(2)(3); // 6
curriedAdd(1, 2)(3); // 6(支持多参数“跳跃”传入,属增强版)
柯里化如何达成部分应用
因为每一步都返回函数,所以任意中间步骤都是“部分应用”的结果:
立即学习“Java免费学习笔记(深入)”;
-
const add5 = curriedAdd(5);→ 固化第一个参数为 5,返回(b, c) => 5 + b + c的柯里化函数 -
const add5and10 = add5(10);→ 再固化第二个参数,返回c => 5 + 10 + c - 这比手动写
const add5 = (b, c) => add(5, b, c)更灵活,且天然支持继续柯里化
注意:柯里化 ≠ 简单的预填参数
像bind或工具函数_.partial属于广义的部分应用,但它们不强制单参数调用链:
-
add.bind(null, 5, 10)→ 直接返回function(c) { return 5 + 10 + c; },一步到位,不可再拆 - 而柯里化保留了“继续分步”的能力,更适合函数组合、高阶抽象(如与
compose配合) - 实际项目中,是否用柯里化取决于场景:配置复用、API 封装、FP 风格编程时更有价值
基本上就这些。柯里化看起来绕,但抓住“单参数 + 闭包 + 延迟执行”三个关键词,就容易理解它怎么把一个函数变成一串可暂停、可复用的小函数了。











