柯里化是将多参数函数转换为依次接收单个参数的函数序列,实现方式是通过闭包保存参数直至数量足够再执行,例如 curry(add)(1)(2)(3) 返回结果,核心在于分步传参与延迟执行,适用于参数复用、函数组合等场景。
柯里化是一种函数式编程技巧,它把接受多个参数的函数转换成一系列只接受一个参数的函数。通过这种方式,我们可以更灵活地复用和组合函数。
假设有一个函数 add(
a, b, c),正常调用是 add(1, 2, 3)。柯里化之后,它可以被这样调用:add(1)(2)(3)。每次调用返回一个新的函数,直到所有参数都被传入,最终执行并返回结果。
核心思想是:延迟执行。我们不必一次性提供所有参数,可以逐步传入,适用于参数复用的场景。
以一个简单的加法函数为例:
function add(a, b, c) { return a + b + c; }我们来写一个通用的柯里化函数:
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 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 属性获取形参个数,当收集的参数足够时就执行原函数。
柯里化在实际开发中非常有用,尤其是在需要配置或预设部分参数的场景。
柯里化虽然强大,但也不是万能的。
基本上就这些。掌握柯里化,能让 JavaScript 函数式编程更得心应手。关键在于理解“分步传参”和“延迟执行”的本质。不复杂但容易忽略细节。