reduce的使用 (完整版)

Posted 蟹蟹!

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了reduce的使用 (完整版)相关的知识,希望对你有一定的参考价值。

作用:reduce方法es6新增方法,通常被作用域累加器,但其实reduce其实不至于此

语法:

Array.reduce(callback(accumulator, currentValue[, index[, array]])[, initialValue])

数组.reduce(function(累加器,遍历元素,[索引[, 参与循环的数组]])[, 起始要参与运算的参数])

参数:

callback:执行数组中每个值 (如果没有提供 initialValue则第一个值除外)的函数,包含四个参数:
-----accumulator:累计器累计回调的返回值; 它是上一次调用回调时返回的累积值,或initialValue(见于下方)。
-----currentValue:数组中正在处理的元素。
-----index可选 数组中正在处理的当前元素的索引。 如果提供了initialValue,则起始索引号为0,否则从索引1起始。
-----array可选 调用reduce()的数组
initialValue: 可选 作为第一次调用 callback函数时的第一个参数的值。 如果没有提供初始值,则将使用数组中的第一个元素。 在没有初始值的空数组上调用 reduce 将报错。(第一次循环的值).

1.当累加器使用

//数组.reduce(函数体(积累的返回值, 正在处理的元素[, 索引[,正在处理的数组]])[, 循环开始的起始值])
let a = [1, 2, 3, 4, 5]
let b = a.reduce(function(accumulator,currentValue,index,array){
    console.log(index);// 索引号
    console.log(array);// [1, 2, 3, 4, 5]
    return accumulator+=currentValue
},5)//敲黑板这个0   是开始那个和索引为1相加  默认不给就是1+2+3+4+5  给5就是5+1+2+3+4+5   给6就是6+1+2+3+4+5
console.log(a);//a: [1, 2, 3, 4, 5]
console.log(b);//b: 20

2.计算一个数据里重复的元素次数

let arr = ["a", "b", "c", "b", "z", "a", "c", "b", "d", "c", "x", "b", "z", "c", "z", "x", "c", "b", "a"]
const obj = arr.reduce((sum,item)=>{
     sum[item] ? sum[item]++ : sum[item] = 1
     return sum
},{})
console.log(obj);

以上是关于reduce的使用 (完整版)的主要内容,如果未能解决你的问题,请参考以下文章

几个关于js数组方法reduce的经典片段

中国移动短信网关错误代码汇总(完整版)

《蒂凡尼的早餐》片段

几个关于js数组方法reduce的经典片段

C#支付宝扫码支付代码完整版(转)

数据挖掘导论 完整版+PPT+Python R代码