问题:求add(1,2)add(1,2,3)add(1)(2)(3)的函数实现:
function add(a){
var args=arguments.length;
var sum=arguments[0];
if(args>1){
for(var i=1;i<args;i++){
sum+=arguments[i];
}
return sum;
}
else{
var temp=function(b){
sum=sum+b;
return temp;
}
temp.valueOf=temp.toString=function(){
return sum;
}
return temp;
}
}
此段代码主要难点在于递归的理解,上面的temp作为一个可递归的函数只负责递归,所以其每次返回的是temp本身,起到不让地轨链断裂的效果,而sum才是实际上进行计算存储求和的变量,但是这里并没有将sum的值返回出来所以外界是得不到最终的结果的,于是乎就有了valueOf和toString这两个属性的重写的需求,因为在每次返回temp的时候总是会去调用valueOf或者toString去的到他的值并返回,所以这里给他的属性值进行重写,另其等于sum值,然后就可以实现虽然返回的是temp,但实际上返回的是sum的值。