• js中reduce()的使用


     当在reduce()方法中设置了初始值时,在计算和的过程中,初始值会作为累加器的初始值。累加器是一个中间变量,用于存储每一次迭代计算的结果。

    假设我们有一个数组[1, 2, 3, 4],并且我们设置初始值为0。那么在每一次迭代中,累加器的初始值为0,然后依次将数组中的元素与累加器进行相加。

    (1)第一次迭代时,累加器的值为0,数组的第一个元素是1,所以计算结果为0 + 1 = 1。

    (2)第二次迭代时,累加器的值为1,数组的第二个元素是2,所以计算结果为1 + 2 = 3。

    (3)第三次迭代时,累加器的值为3,数组的第三个元素是3,所以计算结果为3 + 3 = 6。

    (4)第四次迭代时,累加器的值为6,数组的第四个元素是4,所以计算结果为6 + 4 = 10。

    最后,reduce()方法返回累加器的最终值,即10。

    总结起来,设置初始值后,reduce()方法会从初始值开始,依次将数组中的元素与累加器进行操作,直到遍历完所有元素并返回最终的累加器值。

    1. const numbers = [1, 2, 3, 4, 5];
    2. const sum = numbers.reduce((accumulator, currentValue) => {
    3. return accumulator + currentValue;
    4. });
    5. console.log(sum); // 输出: 15

    在上面的例子中,我们调用了reduce()方法,并传入一个回调函数作为参数。回调函数接受两个参数:accumulatorcurrentValue。在每次迭代中,回调函数将当前值 currentValue 加到累加器 accumulator 上,并将结果返回。最终,reduce()方法返回累加器的值,即计算出的总和。

    需要注意的是,在上面的例子中,我们没有提供初始值,因此reduce()方法从数组的第一个元素开始迭代。如果我们想自定义初始值,可以将其作为reduce()方法的第二个参数传入:

    1. const numbers = [1, 2, 3, 4, 5];
    2. const initialValue = 10;
    3. const sum = numbers.reduce((accumulator, currentValue) => {
    4. return accumulator + currentValue;
    5. }, initialValue);
    6. console.log(sum); // 输出: 25

    在这个例子中,我们将初始值设置为10,然后再将数组中的每个元素加到累加器上。最终,我们得到的总和是25。

    这就是reduce()方法的基本用法和参数的作用。通过灵活使用回调函数和初始值,我们可以根据具体需求执行各种累积计算操作。

    =========================================================================

    1. const array = [1, 2, 3, 4];
    2. const result = array.reduce((accumulator, currentValue, index, array) => {
    3. // 在这里可以使用累加器、当前值、当前索引和原始数组进行操作
    4. // 这里只是一个简单的示例,将累加器和当前值相乘
    5. return accumulator * currentValue;
    6. });
    7. console.log(result);

    在这个例子中,我们有一个包含数字的数组array,我们想要计算所有数字的乘积。

    reduce()方法中,我们传入一个回调函数作为参数。这个回调函数有四个参数:accumulatorcurrentValueindexarray

    第一次迭代时,accumulator的值是数组的第一个元素1,currentValue的值是数组的第二个元素2,index的值是1,array的值是原始数组[1, 2, 3, 4]。

    在回调函数中,我们将累加器和当前值相乘,并将结果返回给累加器。在第一次迭代后,累加器的值变为1 * 2 = 2。

    第二次迭代时,accumulator的值是上一次迭代的结果2,currentValue的值是数组的第三个元素3,index的值是2,array的值是原始数组[1, 2, 3, 4]。

    在回调函数中,我们将累加器2和当前值3相乘,并将结果返回给累加器。在第二次迭代后,累加器的值变为2 * 3 = 6。

    继续进行下一次迭代,直到处理完所有的数组元素。

    最后,reduce()方法返回累加器的最终值,即24

    注:index和array是可以忽略不写的

  • 相关阅读:
    STC单片机25——串口(字节的发送与接收)
    D. Corrupted Array
    Windows Docker Desktop安装K8S
    ES9,ES10
    C++ 文件和流
    《单片机原理及应用》——概述
    前后端分离,SpringBoot如何实现验证码操作
    深度学习_3_张量运算
    php练习02
    『力扣刷题本』:合并两个有序链表(递归解法)
  • 原文地址:https://blog.csdn.net/czlj1998/article/details/133191688