Javascript:数组reduce累计方法

  • Array是内置的构造函数,用于创建数组
  • 创建数组建议使用字面量创建,不用Array构造函数创建

例如:

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>

<body>
  <script>
    const arr = new Array(1, 3, 5)
    console.log(arr)
  </script>
</body>

</html>

在这里插入图片描述

数组实例方法reduce

  • 数组实例方法reduce,是累计器,返回累计处理的结果,常用于求和等。

基本语法:

arr.reduce(function(上一次值, 当前值) {}, 初始值)

如果有初始值这个参数,则把初始值累加到里面。如果没有初始值,则只计算数组元素。

reduce的执行过程:

  • 如果没有初始值,则开始把数组的第一个元素的值作为上一次的值。
  • 每一次循环,把返回值作为下一次循环的上一次值。
  • 如果有起始值,则把起始值作为上一次值。

示例:没有初始值的情况

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>

<body>
  <script>
    const arr = [1, 5, 8]

    // 1. 没有初始值的情况
    const total = arr.reduce(function (prev, current) {
      return prev + current
    })
    console.log(total)
  </script>
</body>

</html>

在这里插入图片描述

示例:有初始值的情况

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>

<body>
  <script>
    const arr = [1, 5, 8]
    // 有初始值的情况
    const total = arr.reduce(function (prev, current) {
      return prev + current
    }, 10)
    console.log(total)
  </script>
</body>

</html>

在这里插入图片描述

示例:用箭头函数

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>

<body>
  <script>
    const arr = [1, 5, 8]
    // 箭头函数的写法
    const total = arr.reduce((prev, current) => prev + current, 10)
    console.log(total)
  </script>
</body>

</html>

在这里插入图片描述

示例:数组元素是对象时,要将初始值设置为0

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>

<body>
  <script>
    const arr = [{
      name: '张三',
      salary: 10000
    }, {
      name: '李四',
      salary: 10000
    }, {
      name: '王五',
      salary: 10000
    },
    ]

	// 数组元素是对象时,初始值不能省略,设置为0
    const total = arr.reduce((prev, current) => {
      return prev + current.salary
    }, 0)
    console.log(total)
  </script>
</body>

</html>

在这里插入图片描述

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: "reduce" 方法JavaScript数组的一种高阶函数,它可以对数组中的每个元素进行迭代,并生成一个单一的最终结果。它通过接收一个函数作为参数,该函数对每个元素执行计算,并将上一次的计算结果和当前元素作为参数传递给下一次计算。 举个例子,我们可以使用 "reduce" 方法数组求和: ``` const numbers = [1, 2, 3, 4]; const sum = numbers.reduce(function(accumulator, currentValue) { return accumulator + currentValue; }, 0); console.log(sum); // 10 ``` 在这个例子中,初始值是 0,然后对数组中的每个元素执行计算,并将累加器的值与当前元素的值相加,最终结果为 10。 ### 回答2: reduce()方法Javascript数组对象的一个方法,用于对数组中的每个元素进行累积计算。该方法接收两个参数,第一个参数是一个回调函数,第二个参数是一个可选的初始值。 回调函数有四个参数:累积值(即上一次回调函数的返回值或初始值),当前值,当前索引,原数组。回调函数可以返回任何值,返回的值将成为下一次回调函数的累积值。 reduce()方法数组的第一个元素开始,依次对数组中的每个元素调用回调函数,并将返回值作为下一次调用的累积值。最后返回最终的累积值。 如果没有提供初始值作为第二个参数,reduce()方法将以数组的第一个元素作为初始值,并从第二个元素开始调用回调函数。 reduce()方法可以用于各种累积计算,如求和、求乘积、找到最大值、最小值等。通过在回调函数中操作累积值和当前值,可以实现不同的计算。 以下是一个对数组元素求和的例子: ```javascript const arr = [1, 2, 3, 4, 5]; const sum = arr.reduce((accumulator, currentValue) => { return accumulator + currentValue; }, 0); console.log(sum); // 输出15 ``` 在这个例子中,初始值为0,回调函数将累积值和当前值相加,并返回结果。最终得到数组元素的和为15。 需要注意的是,reduce()方法不会改变原数组,它返回的是一个新的累积值。如果数组为空并且没有提供初始值,reduce()方法将抛出一个TypeError。 总而言之,reduce()方法是一种强大的数组处理工具,可以简洁高效地实现各种累积计算操作。 ### 回答3: reduce()方法JavaScript数组对象中的一个高阶函数,它用于将数组中的所有元素通过一个指定的函数累计计算成一个单一的值。 reduce()方法接受两个参数,第一个参数是一个回调函数,用于对数组中的每个元素进行处理;第二个参数可选,表示累计计算的初始值。回调函数接受四个参数,分别是累计计算的结果、当前处理的元素、当前元素的索引和原始数组。 回调函数在每次迭代中将累计计算的结果和当前元素进行处理,得到新的结果,然后继续处理下一个元素。最终,reduce()方法返回的是最后一次累计计算得到的结果。 reduce()方法的使用场景非常广泛。可以用它来实现数组求和、求平均值、找出最大值或最小值,以及一些更复杂的计算。此外,reduce()方法还可以用于合并多个数组、过滤数组中的元素或对数组进行转换等操作。 下面是一个示例,展示了如何使用reduce()方法来计算数组中所有元素的和: ```javascript const numbers = [1, 2, 3, 4, 5]; const sum = numbers.reduce((accumulator, currentValue) => accumulator + currentValue, 0); console.log(sum); // 输出15 ``` 在上面的示例中,初始值为0,回调函数对每个元素进行累加操作,最终得到数组中所有元素的和。 需要注意的是,reduce()方法在空数组上是不可用的,所以在使用之前应该确保数组非空,或者使用可选的第二个参数来指定初始值。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值