• 技术文章 >web前端 >js教程

    怎么用JavaScript求数组的总和

    青灯夜游青灯夜游2021-11-23 18:18:15原创577

    方法:1、用“arr.reduce(function f(pre,curr){return pre+cur})”语句;2、用“arr.reduceRight(function f(pre,curr){return pre+cur})”。

    本教程操作环境:windows7系统、javascript1.8.5版、Dell G3电脑。

    用JavaScript求数组的总和

    方法1:使用reduce()

    reduce() 将数组元素计算为一个值(从左到右)。

    var a = [1, 2, 3, 4, 5];
    var b =a.reduce(function f(pre, curr){
    	return pre + curr;
    	});
    console.log(b);

    1.png

    说明:

    reduce() 方法可对数组中的所有元素调用指定的回调函数。该回调函数的返回值为累积结果,并且此返回值在下一次调用该回调函数时作为参数提供。具体用法如下:

    array.reduce(callbackfn[, initialVaule]);

    参数说明:

    reduce() 方法的返回值是通过最后一次调用回调函数获得的累积结果。

    如果提供了参数 initialVaule,则 reduce() 方法会对数组中的每个元素调用一次 callbackfn 函数(按升序索引顺序);如果为提供 initialVaule,则 reduce() 方法会对从第 2 个元素开始的每个元素调用 callbackfn 函数。

    回调函数的返回值在下一次调用回调函数时作为 previousValue 参数提供。最后一次调用回调函数获得的返回值为 recude() 方法的返回值。该方法不为数组中缺少的元素调用该回调函数。

    回调函数的语法如下:

    function callbackfn(previousValue, currentVaule, currentIndex, array);

    回调函数参数说明:

    在第一次调用回调函数时,作为参数提供的值取决于 reduce() 方法是否具有 initialValue 参数。如果向 recude() 方法提供 initialValue,则 previousValue 参数为 initialValue,currentValue 参数是数组中第 1 个元素的值。

    方法2:使用reduceRight()

    reduceRight() 将数组元素计算为一个值(从右到左)。

    var arr = [1, 2, 3, 4, 5, 5];
    var b =arr.reduceRight(function f(pre, curr){
    	return pre + curr;
    	});
    console.log(b);

    2.png

    说明:

    reduceRight() 方法可从右向左对数组中的所有元素调用指定的回调函数。该回调函数的返回值为累积结果,并且此返回值在下一次调用该回调函数时作为参数提供。具体用法如下:

    array.reduceRight(callbackfn[, initialValue]);

    该方法的语法和用法与 reduce() 方法大概相同,唯一不同的是,它是从数组右侧开始调用回调函数。如果提供了 initialValue,则 reduceRight() 方法会按降序索引顺序对数组中的每个元素调用一次 callbackfn 函数。如果未提供 initialValue,则 reduceRight() 方法会按降序索引顺序对每个元素(从倒数第 2 个元素开始)调用 callbackfn 函数。

    【推荐学习:javascript高级教程

    以上就是怎么用JavaScript求数组的总和的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:JavaScript 数组 数组和
    上一篇:jquery怎样判断点击了第几个元素 下一篇:jquery怎样实现点击显示元素再次点击隐藏元素
    千万级数据并发解决方案

    相关文章推荐

    • javascript的引用数据类型是什么• javascript怎么将对象转化为数组• javascript中什么是回流• javascript是强类型语言吗• javascript的dom事件有哪些
    1/1

    PHP中文网