在网上看到了一道关于柯里化的经典面试题
// 实现一个add方法,使计算结果能够满足如下预期:
add(1)(2)(3) = 6;
add(1, 2, 3)(4) = 10;
add(1)(2)(3)(4)(5) = 15;
function add() {
// 第一次执行时,定义一个数组专门用来存储所有的参数
var _args = Array.prototype.slice.call(arguments);
// 在内部声明一个函数,利用闭包的特性保存_args并收集所有的参数值
var _adder = function() {
_args.push(...arguments);
return _adder;
};
// 利用toString隐式转换的特性,当最后执行时隐式转换,并计算最终的值返回
_adder.toString = function () {
return _args.reduce(function (a, b) {
return a + b;
});
}
return _adder;
}
// 这里直接console无法达到预期需要tostring()隐式转换一下
// 不是转换,是利用了toString 隐式调用的特性,也就是说,当_adder这个方法调用了自己toString 的时候执行你贴出来这段,然后出结果
// 前面几次循环不会调用toString 所以前面不断递归,最后一次计算。这是利用子函数孙子函数以及toString 隐式调用特点
add(1)(2)(3) // 6
add(1, 2, 3)(4) // 10
add(1)(2)(3)(4)(5) // 15
add(2, 6)(1) // 9
https://www.jianshu.com/p/2975c25e4d71