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

柯里化(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));
};
}
};
}
</font>
<p>例如:</p><div class="aritcle_card flexRow">
<div class="artcardd flexRow">
<a class="aritcle_card_img" href="/ai/838" title="A1.art"><img
src="https://img.php.cn/upload/ai_manual/001/503/042/68b6d76a86508452.png" alt="A1.art" onerror="this.onerror='';this.src='/static/lhimages/moren/morentu.png'" ></a>
<div class="aritcle_card_info flexColumn">
<a href="/ai/838" title="A1.art">A1.art</a>
<p>一个创新的AI艺术应用平台,旨在简化和普及艺术创作</p>
</div>
<a href="/ai/838" title="A1.art" class="aritcle_card_btn flexRow flexcenter"><b></b><span>下载</span> </a>
</div>
</div><p><span>立即学习</span>“<a href="https://pan.quark.cn/s/c1c2c2ed740f" style="text-decoration: underline !important; color: blue; font-weight: bolder;" rel="nofollow" target="_blank">Java免费学习笔记(深入)</a></a>”;</p>
<font color="#666">
<pre class="brush:php;toolbar:false;">
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)}
基本上就这些。它不复杂,但容易忽略闭包和参数长度判断这两个关键点。










