柯里化是将多参数函数转换为依次接收单个参数的函数序列,实现方式是通过闭包保存参数直至数量足够再执行,例如 curry(add)(1)(2)(3) 返回结果,核心在于分步传参与延迟执行,适用于参数复用、函数组合等场景。

柯里化是一种函数式编程技巧,它把接受多个参数的函数转换成一系列只接受一个参数的函数。通过这种方式,我们可以更灵活地复用和组合函数。
什么是柯里化
假设有一个函数 add(a, b, c),正常调用是 add(1, 2, 3)。柯里化之后,它可以被这样调用:add(1)(2)(3)。每次调用返回一个新的函数,直到所有参数都被传入,最终执行并返回结果。
核心思想是:延迟执行。我们不必一次性提供所有参数,可以逐步传入,适用于参数复用的场景。
手动实现一个柯里化函数
以一个简单的加法函数为例:
立即学习“Java免费学习笔记(深入)”;
function add(a, b, c) { return 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这里利用了函数的 length 属性获取形参个数,当收集的参数足够时就执行原函数。
柯里化的实际用途
柯里化在实际开发中非常有用,尤其是在需要配置或预设部分参数的场景。
- 创建可复用的工具函数,比如日志记录:log(level)(message),可以预先定义 errorLog = log('error')
- 事件处理中绑定固定参数,避免内联函数重复创建
- 与函数组合(compose)配合使用,提升代码表达力
注意点
柯里化虽然强大,但也不是万能的。
- 不适用于动态参数(如 arguments)的函数,最好使用固定参数函数
- 过度使用可能导致代码难以理解,尤其是嵌套层级过深
- 每次调用都会返回新函数,可能带来轻微性能开销
基本上就这些。掌握柯里化,能让 JavaScript 函数式编程更得心应手。关键在于理解“分步传参”和“延迟执行”的本质。不复杂但容易忽略细节。











