柯里化函数实现
2019-03-12 本文已影响0人
企鹅的技术笔记
柯里化函数实现
柯里化函数的实现实质上是一个收集参数的过程, 也许柯里化的内涵及应用场景理解起来比较困难, 但是实现是相对简单的
const curry = (fn) => {
/**
*
* @param {number} rest_num 剩余需要收集的参数数目
* @param {array} args_list 参数列表
*/
const _c = (rest_num, args_list) => {
if (rest_num <= 0) {
return fn(...args_list);
}
return (...args) => _c(rest_num - args.length, [...args_list, ...args])
}
return _c(fn.length, []);
}
// example
const plus = (a, b, c, d) => a + b + c + d;
const curry_plus = curry(plus);
curry_plus(1, 2, 3, 4) // 10
curry_plus(1)(2, 3, 4) // 10
curry_plus(1)(2)(3, 4) // 10
如上述示例, curry函数会返回一个 _c, 在使用者每一次调用 curry_plus 的时候会让 _c 传入的 rest_num 都减去相应的值, 当不再需要收集参数时, 就返回结果