柯里化是将多参数函数转为单参数函数链的技术,通过闭包保存已传参数实现分步调用;如add(1)(2)(3)等价于add(1,2,3),支持暂停、复用与组合;通用实现依赖fn.length判断参数是否齐备,不足则递归返回新函数。
柯里化是一种将接收多个参数的函数,转换为一系列只接收一个参数的函数的技术。它的核心思想是“参数分步传入”,每次调用只传一个参数,返回一个等待下一个参数的新函数,直到所有参数都传完,才执行原函数并返回最终结果。
它不是简单地把参数拆开,而是通过闭包保存已传入的参数,形成链式调用。比如 add(1)(2)(3) 等价于 add(1, 2, 3),但前者支持中途暂停、复用和组合。
可以基于函数的 length 属性(形参个数)来判断是否收集齐参数:
fn
fn.apply() 执行;不够就返回新的柯里化函数示例代码:
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));
};
}
};
}
柯里化在函数式编程中很实用,比如配置复用或预设行为:
认前缀的日志函数:const logError = curry(console.log)('[ERROR]');,之后调用 logError('network failed')
const isGreaterThan = curry((min, val) => val > min); const isPositive = isGreaterThan(0);
map 或 filter 使用时更简洁,避免写箭头函数包装柯里化依赖函数声明时的形参个数,对不定参数(...args)、箭头函数或动态参数处理较弱;ES6+ 中部分内置方法(如 Array.prototype.map)不支持直接柯里化调用,需封装。另外,过度柯里化可能影响可读性,应权衡简洁性与意图表达。