Javascript reduce方法

 

reduce方法接收一个函数作为累加器,数组中的每个值(从左至右)开始缩减,最终计算为一个值

注意:reduce()对于空数组是不会执行回调函数

语法:

array.reduce(function(total, currentValue, currentIndex, arr), initialValue)

       var arr=[0,1,2,3,4]
            var sum = arr.reduce(function(total,currentVal,index,arr){
                return total + currentVal //等同于 total = total + currentVal
            },5);
            console.log(sum) //15

 initVal为函数的初始值

当不传该值的时候,

       var arr=[0,1,2,3,4]
            var sum = arr.reduce(function(total,currentVal,index,arr){
                    return  total = total + currentVal;
            });
            console.log(sum) //10

 内部执行顺序为

index的值是从1开始的,total的初始值为index=0的value,而后再循环累加

在函数的参数里面,total的描述为,初始值,或是计算结束后端的返回值,咦,难道total作为初始值使用的时候和initVal的结果是一样的;

       var arr=[0,1,2,3,4]
            var sum = arr.reduce(function(total,currentVal,index,arr){
                    total = 5;
                    return  total = total + currentVal;
            });
            console.log(sum) //9

我且先给total一个初始值,按照理想的应该输出的是14,可是结果输出的是9;

看运行过程

total的值一直为5,原来每一次运行都要重新赋值一遍total,所以结果是每次的固定total值与当前的currentVal相加,所以最后得到的值为9

所以,目前写下来,觉得total作为初始值处理的意义不大,如果要想给初始值还是initVal用起来方便。

若数组为空数组;

       var arr=[]
            var sum = arr.reduce(function(total,currentVal,index,arr){
                   console.log(total,currentVal,index,arr)//不会输出
                   return  'a' //不会返回
            },1);
            console.log(sum) //1 有初始值的情况下,返回初始值,没有初始值直接报错

 

当数组有空项的时候,直接跳过

       var arr=[0,1,,,4]
            var sum = arr.reduce(function(total,currentVal,index,arr){
                   console.log(total,currentVal,index,arr)
                   return  total=total+currentVal
            });
            console.log(sum) //5

  

 

posted @ 2018-06-07 15:11  伊优  阅读(240)  评论(0编辑  收藏  举报