1 如果数组中存在 item,则返回元素在数组中的位置,否则返回 -1
function indexOf(arr, item) {
      if(Array.prototype.indexOf){
            return arr.indexOf(item);
      }else{
            for(var i=0;i<arr.length;i++){
                  if(arr[i]===item){
                        return i;
                  }
            }
      }
      return -1;
}
2 计算给定数组 arr 中所有元素的总和
递归:
function sum(arr) {
    var len = arr.length;
    if(len == 0){
        return 0;
    } else if (len == 1){
        return arr[0];
    } else {
        return arr[0] + sum(arr.slice(1));
    }
}
常规循环:
function sum(arr) {
    var s = 0;
    for (var i=arr.length-1; i>=0; i--) {
        s += arr[i];
    }
    return s;
}
函数式编程 map-reduce:
function sum(arr) {
    return arr.reduce(function(prev, curr, idx, arr){
        return prev + curr;
    });
}
forEach遍历:
function sum(arr) {
    var s = 0;
    arr.forEach(function(val, idx, arr) {
        s += val;
    }, 0);
  
    return s;
};
eval:
function sum(arr) {
      return eval(arr.join("+"));
}
function remove(arr, item) {
        var arr1 = arr.slice(0);
      for(var i=arr1.length-1;i>=0;i--){
            if(arr1[i]==item){
                  arr1.splice(i, 1);
            }
      }
      return arr1;
}
function remove(arr, item) {
        var arr1 = arr.slice(0);
      for(var i=0; i<arr1.length;i++){
            if(arr1[i]==item){
                  arr1.splice(i, 1);
                  i--;
            }
      }
      return arr1;
}
function remove(arr, item) {
        var arr1 = [];
      for(var i=0; i<arr.length;i++){
            if(arr[i]!==item){
                  arr1.push(arr[i]);
            }
      }
      return arr1;
}
function remove(arr,item){
    return arr.filter(function(ele){
         return ele != item;
    })
}
