函数柯里化也是JS中讲烂的东西了,今天初次接触,结合大佬的文章讲讲自己的理解。参考:https://github.com/mqyqingfeng/Blog/issues/42
柯里化的作用
最直观的用法就是节省代码中共同参数的重复,比如一个函数有四个参数,其中前三个在多次调用中都是一样的,最后一个视情况不同,伪代码如下:
fun(a, b, c, 'hello')
fun(a, b, c, 'world')
为了减少参数的重复,可以把函数curry化
cf = curry(fun, a, b, c)
cf('hello')
cf('world')
以上,日常开发中感觉并不是很用的上。
curry 化的核心
实际上 curry 化的核心思路就是不断返回收集参数的函数,直到参数满足函数调用个数,再调用函数。
这里有两个难点:
- 如何保存未被使用的参数
- 如何返回参数收集函数
我们可以用闭包保存未被使用的参数,而返回参数收集函数是一个递归的过程
全程用ES6代码实现,实例代码并非最简
function curry(fn, ...nargs) {
let args = [...nargs]
return function sub_curry(...nargs) {
// 更新参数列表
args = [...args, ...nargs]
// 判断参数个数是否已经满足
if(args.length === fn.length) {
// 满足直接调用函数
return fn.apply(this, args)
// 参数个数未满足,继续收集参数(调用 sub_curry)
} else if (args.length < fn.length) {
return sub_curry
}
// 这里可以加个 else 抛出参数个数异常
}
}
function add4(a, b, c, d) {
return a + b + c +d;
}
curry(add4) // sub_curry() {} ...
curry(add4, 1, 2, 3, 4) // 10
curry(add4)(1)(2)(3)(4) // 10
curry(add4, 1, 2)(3, 4) // 10
// ...