1. map:映射   一个对一个

arr.map(function(item) { ... })    可以配合箭头函数:arr.map(item => ... )

        let arr1 = [1,2,3]
let result1 = arr1.map(item=>item*2)
console.log(result1) // [2,4,6]
        let score = [56,88,90];
let grade = score.map(item=>item>=60?'及格':'不及格');
console.log(score); // [56, 88, 90]
console.log(grade); // ["不及格", "及格", "及格"]

可以看到一一对应的关系

2. reduce:汇总 一堆对一个

语法:arr.reduce(function(tmp, item, index [,arr]){ ... }[, initialValue])

tmp:初始值,或是上一次的叠加结果值,不指定initialValue时默认为arr[0]的值为起始值

item:当前值

index:当前值在数组中的index值

arr:当前数组,可不写

initialValue:指定初始执行的值

下面给几个例子用于熟悉这几个参数的含义

        let arr2 = [12,69,180,8763]
arr2.reduce((tmp,item,index)=>{
console.log(tmp,item,index)
})
// 12,69,1
     // undefined,180,2
     // undefined,8763,3
        arr2.reduce((tmp,item,index)=>{
console.log(tmp,item,index)
},[])
// [] 12 0
     // undefined,69,1
     // undefined,180,2
     // undefined,8763,3
     arr2.reduce((tmp,item,index)=>{
console.log(tmp,item,index)
},0)
     // 0 12 0
     // undefined,69,1
     // undefined,180,2
     // undefined,8763,3

tmp是初始值或是上一次的叠加结果值,所以第一个我们可以看到tmp是有值的:

当有initialValue时显示为initialValue值,如果initialValue缺省则显示arr[0]的值,即12

后面剩下的循环这里undefined是因为reduce里面没有写两者相加这个语句,所以tmp这个值是没有的

在function里添加tmp+item,看下面这两个例子:

        arr2.reduce((tmp,item,index)=>{
console.log(tmp,item,index)
return tmp+item
},[])
// [] 12 0
     // 12,69,1
     // 1269,180,2
     // 1269180,8763,3   // 这里明显是字符串的拼接了,因为初始值是[],所以tmp+item是按照字符串拼接的方式相加的 let result2 = arr2.reduce((tmp,item,index)=>{
console.log(tmp,item,index)
return tmp+item
}, 0)
// 0 12 0
     // 12,69,1
     // 81,180,2
     // 261,8763,3 console.log(result2) // 9024 result2最后是最终求和的结果

如果想求平均值呢?逻辑是:前面循环求和,最后一次求和后除以数组个数,即:

        let result3 = arr2.reduce((tmp,item,index)=>{
if(index!=arr2.length-1){ // 不是最后一个
return tmp+item
}else { // 是最后一个
return (tmp+item)/arr2.length
}
})
console.log(result3) // 2256 求平均值

3. filter 过滤  返回值是符合过滤条件的元素

arr.filter(function(){ ... })

        let arr3 = [22,5,63,34,12,7,69]
let result4 = arr3.filter(item=>item%3==0) console.log(result4) // [63, 12, 69]

filter在循环的过程中有一个判断过程,是true则返回,false则去掉

4. forEach  循环迭代

arr.forEach(function(item, index){ ... })

ES6 —— 数组总结的更多相关文章

  1. ES6数组扩展

    前面的话 数组是一种基础的JS对象,随着时间推进,JS中的其他部分一直在演进,而直到ES5标准才为数组对象引入一些新方法来简化使用.ES6标准继续改进数组,添加了很多新功能.本文将详细介绍ES6数组扩 ...

  2. ES6数组及数组方法

    ES6数组可以支持下面的几种写法: (1)var [a,b,c] = [1,2,3]; (2)var [a,[[b],c]] = [1,[[2],3]]; (3)let [x,,y] = [1,2,3 ...

  3. 数组的复制及ES6数组的扩展

    一.数组的复制 // alert([1,2,3]==[1,2,3]); let cc = [0,1,2]; let dd = cc; alert(dd==cc);//此时改变dd会影响cc ES5 只 ...

  4. es6数组的扩展

    数组扩展运算符 ...(三个点) const demoArr=[0,1,2,3,4] console.log(...demoArr) // 0 1 2 3 4 // 他把一个数组用逗号分隔了出来 // ...

  5. ES6 数组方法拓展

    ES6 数组方法拓展 1.Array.from() Array.from方法用于将两类对象转为真正的数组:类似数组的对象(array-like object)和可遍历(iterable)的对象(包括E ...

  6. ES6数组相关

    ES6数组新增的几个方法: 1. forEach() //forEach()遍历数组,无返回值,不改变原数组 var arr=[1,2,3,4] arr.forEach((item,index,arr ...

  7. ES6数组新加 Buff

    欢迎关注本人公众号<迈向大前端>,里面有15本前端相关的电子书,送给在前端路上迷茫的同学们! 本章篇幅很长,分开来发,这一小篇主要讲ES6数组的Array.of()和Array.from( ...

  8. ES6数组的扩展--Array.from()和Array.of()

    一. Array.from() : 将伪数组对象或可遍历对象转换为真数组 1.何为伪数组 如果一个对象的所有键名都是正整数或零,并且有length属性,那么这个对象就很像数组,语法上称为"类 ...

  9. JavaScript ES6 数组新方法 学习随笔

    JavaScript ES6 数组新方法 学习随笔 新建数组 var arr = [1, 2, 2, 3, 4] includes 方法 includes 查找数组有无该参数 有返回true var ...

  10. 关于 ES5 & ES6 数组遍历的方法

    ES5 数组遍历方法 1.for 循环 , , , , ] ; i < arr.length; i++) { console.log(arr[i]) } 2.forEach , , , , ] ...

随机推荐

  1. WEB UI 上传URL附件(使用方法备份)

    FUNCTION zcrm_update_atta. *"------------------------------------------------------------------ ...

  2. HDFS的上传与下载(put & get)

    最近在做一个小任务,将一个CDH平台中Hive的部分数据同步到另一个平台中.毕竟我也刚开始工作,在正式开始做之前,首先进行了一段时间的练习,下面的内容就是练习时写的文档中的内容.如果哪里有错误或者疏漏 ...

  3. 数学运算比IF要快

    问题 虽然很早就知道,CPU在处理 if 这样的判断语句时,使用了预测的技术,所以如果条件总是一个结果,效率就很好.反过来说,如果你使用数学运算避免 if 判断,那么就意味着性能一定比 if 要好. ...

  4. 【转】依赖注入的威力,.NET Core的魅力:解决MVC视图中的中文被html编码的问题

    有园友在博问中提了这样一个问题 —— .NET Core 中文等非英文文字html编码输出问题,到我们的 ASP.NET Core 项目中一看,也是同样的问题. 比如下面的Razor视图代码: @{ ...

  5. composer的安装方法 以及 ThinkPHP5安装

    1.下载installer的文件,使用浏览器开启链接:getcomposer.org/installer,下载如下文件到 E:\xs2016\composer, 将installer重命名为compo ...

  6. md 常用语法

    序言: 起因: 因为现在的前端基本上都用上了前端构建工具,那就难免要写一些readme等等的说明性文件,但是这样的文件一般都是.md的文件,编写的语法自然跟其他格式的文件有所区别,置于为什么要用这种格 ...

  7. Trojan.Backdoor分析

    总结:这是一个HTTP的后门,以安装(-in)||移除(-re)||配置(-c)为目的运行此程序时, 必须指定abcd为最后一个参数. 安装时他会把自身拷贝到%SYSTEMROOT%\WINDOWS\ ...

  8. python-并发初学

    一.操作系统简单介绍 1.多道技术:(重点)系统内可同时容纳多个作业.这些作业放在外存中,组成一个后备队列,系统按一定的调度原则每次从后备作业队列中选取一个或多个作业进入内存运行,运行作业结束.退出运 ...

  9. numpy数组及处理:效率对比

    def Sum(n): #定义一个函数(注意:格式对齐,否则会出错) a=list(range(n)) b=list(range(0,50000*n,5)) c=[] for i in range(l ...

  10. oralce执行计划

    看懂Oracle执行计划   最近一直在跟Oracle打交道,从最初的一脸懵逼到现在的略有所知,也来总结一下自己最近所学,不定时更新ing… 一:什么是Oracle执行计划? 执行计划是一条查询语句在 ...