柯里化是将多参数函数转换为一系列单参数函数的过程,通过闭包累积参数直至满足原函数形参个数才执行;支持提前绑定、函数复用与配置化,适用于日志封装、数组操作及高阶函数构建等场景。
柯里化(Currying)是把一个接收多个参数的函数,转换成一系列只接收一个参数的函数的过程。每次调用返回一个新的函数,直到所有参数都传完,才真正执行原函数。
它不是简单地“分次传参”,而是通过闭包保存已传入的参数,逐步累积,最终触发计算。关键在于:参数数量固定、每次只收一个、返回函数而非结果。
可以借助函数的 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));
};
}
};
}
用法示例:
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
柯里化不是炫技,它在简化配置、封装逻辑、提升可读性上很实用。
log(level, message) → const error = curry(log)('ERROR'),后续只需传 message[1,2,3].map(curry(Math.pow)(2)) 得到平方数组 [1,4,9]
fn.bind(null, a) 更灵活,支持链式传参且不依赖 thisconst match = curry((regex, str) => str.match(regex)),再写 co
nst hasNumber = match(/\d+/)
柯里化适合参数明确、顺序固定的函数。遇到以下情况要谨慎:
基本上就这些。柯里化本质是函数式编程中“分解与组合”的体现,用得好能让代码更清晰、更可复用,但别为了柯里化而柯里化。