1、
function adder( me ) {
var slice = Array.prototype.slice, args = slice.call(arguments);
return function () {
var inargs = slice.call(arguments);
if( arguments.length == 0 ){
var me = 0 ;
for(var i in args){
me +=args[i];
}
return me ;
}
else return adder.apply(this, args.concat(inargs))};
}
console.log(adder(1)(2,3)(5)());
2、
function add(x) {
//由于要一个数记住每次的计算值,所以使用了闭包,在addFake中记住了x的值,第一次调用add(),初始化了addFake,并将x保存在addFake的作用链中,然后返回addFake
//保证了第二次调用的是addFake函数,后面的计算都是在条用addFake, 因为addFake也是返回的自己,保证了第二次之后的调用也是调用addFake,而在addFake中将传入的
//参数与保存在作用链中x相加并付给x,这样就保证了计算;但是在计算完成后还是返回了addFake这个函数,这样就获取不到计算的结果了,我们需要的结果是一个计算的数字
//那么怎么办呢,首先要知道JavaScript中,打印和相加计算,会分别调用toString或valueOf函数,所以我们重写addFake的toString和valueOf方法,返回x的值
function addFake(y) {
x = x + y;
return addFake;
};
addFake.toString = addFake.valueOf = function() { return x; };
return addFake;
}
console.log(add(1)(2)(3)(4)(2));
简化上面
const myadd=(x)=>ak=(y)=>(x = x + y, ak).toString=ak.valueOf=()=>x;
console.log(add(1)(2));