转载:http://www.runoob.com/jsref/jsref-reduce.html

JavaScript reduce() 方法-LMLPHP JavaScript Array 对象

实例

计算数组元素相加后的总和:

var numbers = [65, 44, 12, 4];
function getSum(total, num) { return total + num; }
function myFunction(item) { document.getElementById("demo").innerHTML = numbers.reduce(getSum); }

输出结果:

125

定义和用法

reduce() 方法接收一个函数作为累加器,数组中的每个值(从左到右)开始缩减,最终计算为一个值。

reduce() 可以作为一个高阶函数,用于函数的 compose。

注意: reduce() 对于空数组是不会执行回调函数的。


语法

array.reduce(function(total, currentValue, currentIndex, arr), initialValue)

参数

参数描述
function(total,currentValue, index,arr)必需。用于执行每个数组元素的函数。
函数参数:

参数描述
total必需。初始值, 或者计算结束后的返回值。
currentValue必需。当前元素
currentIndex可选。当前元素的索引
arr可选。当前元素所属的数组对象。
initialValue可选。传递给函数的初始值

技术细节

返回值:返回计算结果
JavaScript 版本:ECMAScript 3

更多实例

实例

四舍五入后计算数组元素的总和:

<button onclick="myFunction()">点我</button> <p>数组元素之和: <span id="demo"></span></p>
<script>
    var numbers = [15.5, 2.3, 1.1, 4.7];
    function getSum(total, num) { return total + Math.round(num); }
    function myFunction(item) {
            document.getElementById("demo").innerHTML = numbers.reduce(getSum, 0);
            }
</script>
 
经验证:如果是数组是对象型数组,如var arr=[{a:1},{a:2},{a:3}],那么reduce的initialValue参数不可省略,一般指定为0
05-21 22:40