JavaScript reduce汇总

使用 reduce 和 reduceRight 方法可以汇总数组元素的值。具体用法如下:

1、reduce

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

array.reduce(callbackfun[,initiaValue])
 
//array:一个数组对象。
 
//callbackfun:必需参数,最多可以接收 4 个参数的函数。
//对于数组中的每个元素,reduce 方法都会调用 callbackfun 函数一次。
 
//initiaValue:可选参数,如果指定 initiaValue,则它将用于初始值来积累。
//第一次调用 callbackfun 函数将此值作为参数而非数组值提供

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

如果提供了 initialValue 则 reduce 方法对数组中的每一个元素调用一次 calbackfun函数(按升序索引顺序)。如果未提供 initialValue,则 reduce 方法会对从第二个元素开始的每个元素调用 callbackfun 函数。

回调函数的返回值在下一次调用回调函数时作为 previousValue 参数提供。最后一次调用回调函数获得的返回值作为 reduce方法的返回值。

回调函数语法如下:

function callbackfun(previousValue,currentValue,currentIndex,array)

//previousValuc:通过上一次调用回调函数获得的值。
//如果向 reduce 方法提供 initialValue,则在首次调用函数时,previousValue 为 initialValue。

//currentValue:当前数组元素的值。

//currentlndex:当前数组元素的数字索引。

//array:包含该元素的数组对象。

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

如果未提供 initialValue,则 previousValue 参数是数组中的第 1 个元素的值,curentValue 参数是数组中的第 2 个元素的值。

下面例子,演示将数组值连接成字符串,各个值用 "::" 分隔开。由于未向 reduce 方法提供初始值,第一次调用回调函数时会将 "abc" 作为 previousValue 参数并将 "def" 作为 currentValue 参数。

function appendCurrent(previousValue,currentValue){
    return previousValue + "::" + currentValue;
}
var elements = ["abc","def",123,456];
var result = elements.reduce(appendcurrent);
document.write(result);    //abc::def::123::456

2、reduceRight

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

array.reduceRight(callbackfun[,initiaValue])

该方法的语法和用法与 reduce 方法完全相同,唯一不同的是它是从数组右侧开始调用回调函数

如果提供了 initialValue,则 reduceRight 方法会按降序索引顺序对数组中的每个元素调用一次 callbackfun 函数。如果未提供 initialValue,则 reduceRight 法会按降序索引顺序对每个元素(从倒数第二 i 个元素开始)调用 callbackfun函数。

下面例子,使用 reduceRight 方法,以 "::" 为分隔符,从右到左把数组元素的值连接在一起。

function appendCurrent(previousValue,currentValue){
    return previousValue + "::" + currentValue;
}
var elements = ["abc","def",123,456];
var result = elements.reduceRight(appendcurrent);
document.write(result);    //456::123::def::abc
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值