JavaScript reduceRight() 方法

Array 对象参考手册 JavaScript Array 对象

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

<p>点击按钮计算数组元素的总和。</p>
<button onclick="myFunction()">点我</button>

<p>数组元素总和: <span id="demo"></span></p>

<script>
  var numbers = [65, 44, 12, 4];

  function getSum(total, num) {
    return total + num;
  }

  function myFunction(item) {
    document.getElementById("demo").innerHTML = numbers.reduceRight(getSum);
  }
</script>

尝试一下 »


定义和用法

reduceRight() 方法的功能和 reduce() 功能是一样的,不同的是 reduceRight() 从数组的末尾向前将数组中的数组项做累加。

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


浏览器支持

表格中的数字表示支持该方法的第一个浏览器版本号。

方法
reduceRight() Yes 9.0 3.0 4 10.5

语法

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

参数

参数 描述
function(total,currentValue, index,arr) 必需。用于执行每个数组元素的函数。
函数参数:
参数 描述
total 必需。初始值, 或者计算结束后的返回值。
currentValue 必需。当前元素
currentIndex 可选。当前元素的索引
arr 可选。当前元素所属的数组对象。
initialValue 可选。传递给函数的初始值

技术细节

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

更多实例

从右到左,减去每个数组元素:

<p>点击按钮从右到左,由最后一个元素开始减去每个数组的元素。</p>
<button onclick="myFunction()">点我</button>

<p>计算后的值: <span id="demo"></span></p>

<script>
  var numbers = [2, 45, 30, 100];

  function getSum(total, num) {
    return total - num;
  }

  function myFunction(item) {
    document.getElementById("demo").innerHTML = numbers.reduceRight(getSum);
  }
</script>

尝试一下 »


Array 对象参考手册 JavaScript Array 对象