首页 > Web开发 > 详细

js一些练习题

时间:2018-03-30 18:55:39      阅读:212      评论:0      收藏:0      [点我收藏+]

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("+"));
}

 3 移除数组 arr 中的所有值与 item 相等的元素。不要直接修改数组 arr,结果返回新的数组

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;
    })
}

js一些练习题

原文:https://www.cnblogs.com/xuniannian/p/8677687.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!