贝利信息

JavaScript中什么是柯里化函数_如何实现

日期:2025-12-05 00:00 / 作者:betcha
柯里化是将多参数函数转换为一系列单参数函数的过程,通过闭包保存已传参数,实现延迟执行与参数记忆,核心特征为分步传递、未满则返函数、满足即求值。

柯里化(Currying)是将一个接收多个参数的函数,转换为一系列只接收一个参数的函数的过程。每次调用返回一个新的函数,直到所有参数都传齐,才执行原函数并返回结果。

柯里化的本质是“参数分步传递”

它不是简单地把多参数函数拆开,而是通过闭包保存已传入的参数,逐步累积,最终触发计算。核心在于:延迟执行 + 参数记忆。

手写一个通用柯里化函数

最常用的方式是基于参数长度自动判断是否执行:

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));
      };
    }
  };
}

使用示例:

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

注意边界情况和实用技巧

实项目中需考虑 this 绑定、参数预设、提前终止等细节:

柯里化 vs 普通偏函数(Partial Application)

容易混淆,但有区别:

基本上就这些。柯里化本身不复杂,但容易忽略闭包生命周期和参数收集逻辑。用在配置化函数、API 封装、函数组合(如与 compose 配合)时特别有用。