每天一题,includes

1,387 阅读1分钟

每天一题,坚持思考

题目

实现includes函数,判断当前数组是否包含传入的值。

includes([1, 2, 3], 1); // true
includes([1, 2, 3, NaN, 3, 6], NaN, 0); // true

具体实现

// 整数
function toInt(num) {
  var resNum = num % 1;
  if (resNum) {
    num = num - resNum;
    Math.abs(resNum) > 0.5 && (resNum > 0 ? num ++ : num--);
  }
  return num;
}

// 数字类型
function toNumber(num) {
  if (typeof num !== 'number' || num !== num || (num === Infinity || num === -Infinity)) {
    num = 0;
  }

  num = toInt(num);
  return num;
}

function includes(array, value, fromIndex) {
  var length = isArray(array) ? array.length : 0;
  if (!length) return false;

  fromIndex = toNumber(fromIndex);
  fromIndex = fromIndex > -1 ? fromIndex : fromIndex + length;


  var index = -1 + fromIndex;

  while(++index < length) {
    if (array[index] === value || (array[index] !== array[index] && value !== value)) {
      return true;
    }
  }
  return false;
}

实现思路

参数:

  1. array(Array):被查询的数组;
  2. value(*): 需要查找的值;
  3. fromIndex (Number):查询时候的起始位置 ;

步骤:

  1. 判断当前的array参数是否为数组,并且判断该数组的长度;
  2. fromIndex进行类型判断,判断是否为数字类型,不是则赋值为0。因为数字类型中可能存在带小数的数字,所以对小数取整处理,这里用到了取余的方式来处理;
  3. 这里使用while遍历,第一次遍历时index的值为0,最后index的值等于数组的长度值;
  4. 遍历数组进行成员和value值进行比较,这里有一个值比较特殊就是NaN, 因为NaN 不等于自身,所以这里进行了特别的判断处理,即使是NaN存在并对比的时候能够返回正确的值;

如果读者发现有不妥或者可以改善的地方,欢迎在评论区指出。如果觉得写得不错或者对你有所帮助,可以点赞、评论、转发分享,谢谢~