函数迭代可选参数算法挑战

函数迭代可选参数算法挑战

挑战:

参考:函数迭代可选参数算法挑战

创建一个计算两个参数之和的 function。如果只有一个参数,则返回一个 function,该 function 请求一个参数然后返回求和的结果。

例如,add(2, 3) 应该返回 5,而 add(2) 应该返回一个 function。

调用这个有一个参数的返回的 function,返回求和的结果:
var sumTwoAnd = add(2);
sumTwoAnd(3) 返回 5。

如果两个参数都不是有效的数字,则返回 undefined。

例如:

   add(2, 3) 应该返回 5。
   add(2)(3) 应该返回 5。
   add("http://bit.ly/IqT6zt") 应该返回 undefined。    
   add(2, "3") 应该返回 undefined。
   add(2)([3]) 应该返回 undefined。

答案:

方法 描述
concat() 连接两个或更多的数组,并返回结果。
some() 检测数组元素中是否有元素符合指定条件。
typeof 检测变量的数据类型。
arguments 对应于传递给函数的参数的类数组对象。
拓展运算符(…)用于取出参数对象所有可遍历属性然后拷贝到当前对象。
function add() {
  var arr=[].concat(...arguments);
    if( arr.some(function(ele){
      return typeof ele!="number";
    }) ){    //参数出现非数字类型,返回undefined
      return undefined;
    }
    if( arr.length==2 ){
      return arr[0]+arr[1];
    }
    return function(a){
      if( typeof a != "number" ){  //同上
        return undefined;
      }
      return a+arr[0];
    };
}

add(2,3);

运行结果:

5

在线测试:

函数迭代可选参数算法挑战 | w3cschool

发布了56 篇原创文章 · 获赞 1 · 访问量 838

猜你喜欢

转载自blog.csdn.net/weixin_44790207/article/details/104714459