zoukankan      html  css  js  c++  java
  • JavaScript reduce() 方法

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

    Array 对象参考手册 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
  • 相关阅读:
    linux创建用户和组
    ftp上来显示的时间和系统时间不一致
    在Linux下如何用Shell脚本读写XML?现有一个config.xml(转)
    关于业务主键和逻辑主键
    git push 提示
    浏览器默认样式
    css实现缩进无限嵌套
    使用设置报头x-Frame-Options限制iframe网页嵌套
    chrome控制台小技巧
    git版本库底层命令
  • 原文地址:https://www.cnblogs.com/as007012/p/9531671.html
Copyright © 2011-2022 走看看