JavaScript中的过滤数组,然后将数组中的内容累加的方式

1.首先在学习这两种方法之前要明白过滤器函数filter()的使用

(1)首先我们先创建一个数组

 const arr = [
        { id: 1, name: "宝马", state: true, pirce: 100, count: 1 },
        { id: 1, name: "奥迪", state: false, pirce: 800, count: 2 },
        { id: 1, name: "奔驰", state: true, pirce: 200, count: 3 },
      ];

(2) 将上述数组中state为true的内容筛选出来

const arr = [
        { id: 1, name: "宝马", state: true, pirce: 100, count: 1 },
        { id: 1, name: "奥迪", state: false, pirce: 800, count: 2 },
        { id: 1, name: "奔驰", state: true, pirce: 200, count: 3 },
      ];
      //使用filter()函数进行筛选
      const arr01 = arr.filter((item) => item.state === true);
      console.log(arr01);

(3)这个时候控制台输出的结果为

 这个时候的你需要的内容就被过滤出来了

2 接下来就到我们今天的主题了如何将过滤出来的数组中state等于true的内容和数组中的count值进行相乘,并且累加出来结果。

(1) 首先使用forEach方法

const arr = [
        { id: 1, name: "宝马", state: true, pirce: 100, count: 1 },
        { id: 1, name: "奥迪", state: false, pirce: 800, count: 2 },
        { id: 1, name: "奔驰", state: true, pirce: 200, count: 3 },
      ];
      //使用filter()函数进行筛选
let amt = 0
     arr.filter((item) => item.state).forEach(item=>{
amt += item.pirce * item.count
});
console.log(amt)
     

这个时候的控制台就会输出700,这样我们的目的就达到了

(2)其次使用reduce方法

const arr = [
        { id: 1, name: "宝马", state: true, pirce: 100, count: 1 },
        { id: 1, name: "奥迪", state: false, pirce: 800, count: 2 },
        { id: 1, name: "奔驰", state: true, pirce: 200, count: 3 },
      ];
      //使用filter()函数进行筛选
//reduce函数的使用方法
//arr.filter((item)=>item.state).reduce((累加的结果,循环项)=>{},初始值)
let amt = 0
    const result = arr
        .filter((item) => item.state === true)
        .reduce((amt, item) => {
          return (amt += item.pirce * item.count);
        }, 0);
      console.log(result);
     

同时我们的控制台输出的结果还是700

  • 2
    点赞
  • 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、付费专栏及课程。

余额充值