JavaScript 数组Array-reduce()方法

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

说明

Javascript array reduce()方法同时针对数组的两个值(从左到右)应用一个函数,以便将其缩减为单个值。

语法

array.reduce(callback[, initialValue]);

参数明细

callback−对数组中的每个值执行的函数。

initialValue−用作回调第一次调用的第一个参数的对象。 如果不提供,则跳过第一个循环。

返回值

返回一个带有回调返回值的新数组。

兼容性

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

if (!Array.prototype.reduce) {
   Array.prototype.reduce = function(fun /*, initial*/) {
      var len = this.length;
      
      if (typeof fun != "function")
      throw new TypeError();
      
      // no value to return if no initial value and an empty array
      if (len == 0 && arguments.length == 1)
      throw new TypeError();
      
      var i = 0;
      if (arguments.length >= 2) {
         var rv = arguments[1];
      } else {
         do {
            if (i in this) {
               rv = this[i++];
               break;
            }
            
            // if array contains no values, no initial value to return
            if (++i >= len)
            throw new TypeError();
         }
         while (true);
      }
      for (; i < len; i++) {
         if (i in this)
         rv = fun.call(null, rv, this[i], i, this);
      }
      return rv;
   };
}

示例 - 基本用法

var array = [2, 4, 8];

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

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

示例

var arr = [2, 4, 8];

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

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

示例-传入一个自定义对象

var array = [2, 4, 8];

var result = array.reduce(function () {
	console.log(this);
	return true;
}, document.location);

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

示例 - 返回一个新数组

var array = [1, 2, 3, 4, 5];

var result = array.reduce(function (previous, value) {
	var sum = previous + value;
	console.log(previous, value, sum);
	return sum;
});

console.log(result);  // 15

示例 - 在某个条件进行中断

var array = [2, 4, 8];

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

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