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]

