JavaScript 数组Array-filter()方法

时间:2019-08-20 13:50:49  来源:igfitidea点击:

说明

Javascript array filter()方法创建一个新数组,其中包含通过所提供函数实现的测试的所有元素。

语法

array.filter(callback[, thisObject]);

参数明细

callback−函数,用于测试数组的每个元素。

传递给callback的参数有:

  1. value - 当前索引的值。
  2. index - 当前索引
  3. array - 数组

thisObject—执行回调时用作此对象的对象。

返回值

返回新创建的数组,其中包含来自传递的迭代的所有值。

兼容性

此方法是ECMA-262标准的JavaScript扩展;因此,它可能不会出现在该标准的其他实现中。要使其正常工作,我们需要在脚本的顶部添加以下代码。

if (!Array.prototype.filter) {
   Array.prototype.filter = function(fun /*, thisp*/) {
      var len = this.length;
      if (typeof fun != "function")
      throw new TypeError();
      
      var res = new Array();
      var thisp = arguments[1];
      for (var i = 0; i < len; i++) {
         if (i in this) {
            var val = this[i];   // in case fun mutates this
            if (fun.call(thisp, val, i, this))
            res.push(val);
         }
      }
      return res;
   };
}

示例 - 普通用法

var array = [2, 4, 8];

var result = array.filter(function () {
	console.log(this);
	return true;
});

console.log(result);  // [2, 4, 8]

示例 - 使用callbak参数

var arr = [2, 4, 8];

var result = arr.filter(function (value, index, array) {
	console.log(value, index, array);
	return true;
});

console.log(result);  // [2, 4, 8]

传递自定义的this对象

var array = [2, 4, 8];

var result = array.filter(function () {
	console.log(this);
	return true;
}, document.location); // 传递document.location作为this值

console.log(result);  // [2, 4, 8]

示例 - 模拟false的情况

var array = [2, 4, 8];

var result = array.filter(function (value) {
	if (value === 4) {
		return false;
	}
	return true;
});

console.log(result);  // [2, 8]
console.log(array);   // [2, 4, 8]