前些天看到一张神图:是不是很形象?

一: 数组遍历

Array.prototype.map:(主要为了其返回值)

map() 方法创建一个新数组,其结果是该数组中的每个元素是调用一次提供的函数后的返回值。

const numList = [1,2,3]
// 对数组中的每一项都乘以 3, 然后返回新的数组
const resultLis = numList.map(item=> item * 3)
console.log('旧数组:',numList)
console.log('新数组:',resultLis)

Array.prototype.forEach:(不返回值,但会处理数组)

forEach() 方法对数组的每个元素执行一次给定的函数。

const numList = [1,2,3]
const newArray = []numList.forEach(item => {newArray.push(item + 1)console.log(item+1)
})
console.log(numList,newArray)

Array.prototype.filter:(过滤值,返回符合过滤条件的值的新数组)

filter() 方法创建一个新数组, 其包含通过所提供函数实现的测试的所有元素。

const list  = [1,2,3,4]
// 过滤大于2的值
const filtered = list.filter(item => item > 2)
console.log(list,filtered )

Array.prototype.some:(数组中只要有一个满足条件,就返回true,否则返回false)

some() 方法测试数组中是不是至少有1个元素通过了被提供的函数测试

const list = [1,2,3,4,5]
// 检测数组中的值是否有一个大于2
const result = list.some(item=> item > 2)
console.log(result)

Array.prototype.every:(数值中所有值都满足条件才会返回true,否则返回false)

every() 方法测试一个数组内的所有元素是否都能通过某个指定函数的测试

const list = [2,3,4]
// 检测数组中的所有元素是否都大于3
const result = list.every(item=> item > 3)
console.log(result)

Array.prototype.reduce:(依次处理每个元素,返回处理后的结果)

reduce() 方法对数组中的每个元素执行一个由您提供的reducer函数(升序执行)

个人感觉reduce()方法逼格更高一点

语法:

arr.reduce(callback,[initialValue])

reduce为数组中的每一个元素都执行回调函数(callback), callback可以接收4个参数:

callback:

1:previousValue(初始值) ===> 必须

2:currentValue(当前被处理的元素) ===> 必须

3:index(当前被处理元素在数组中的索引) ===>可选

4:array(调用reduce的数组) ===> 可选

initialValue:

注意:作为第一次调用 callback函数时的第一个参数的值。 如果没有提供初始值,则将使用数组中的第一个元素。 在没有初始值的空数组上调用 reduce 将报错。

例子1:(累加,无初始值)

const list = [1,2,3,4]
const result = list.reduce((pre,curr)=> pre + curr)
console.log(result,'--')

例子1_1:(累加,有初始值)

const list = [1,2,3,4]
const result = list.reduce((pre,curr)=> pre + curr,10)
console.log(result,'--')

列子2:(累加对象数组里的值,无初始值)

const list = [
{name:'super',age:18},
{name:'tiger',age:19},
]
const totalAge = list.reduce((pre,curr)=> pre.age + curr.age)console.log(totalAge)

列子2_1:(累加对象数组里的值,无初始值)

const list = [
{name:'super',age:18},
{name:'tiger',age:19},
]
const totalAge = list.reduce((pre,curr)=> pre.age + curr.age,20)console.log(totalAge)

例子3:(将二维数组转化一维,有点大材小用)

const list = [1,2,[3,4],['superTiger_Y','博客']]
const flattenedList = list.reduce((pre,curr)=> pre.concat(curr),[])
console.log(flattenedList )

例子4:(计算数组中每个元素出现的次数)

const names = ['Alice', 'Bob', 'Tiff', 'Bruce', 'Alice']const countNames = names.reduce((pre,curr)=> {curr in pre ? pre[curr]++ : pre[curr] = 1return pre
},{})console.log(countNames)

例子5:(按属性对object分类)

const people = [{name:'super',age:21},{name:'tiger',age:22},{name:'_Y',age:21},
]function groupBy(objectArray,property){return objectArray.reduce((pre,curr)=>{const key = curr[property]if(!pre[key]){pre[key] = []}pre[key].push(curr)return pre},{})}const result = groupBy(people ,'age')console.log(result)

 例子6(对象数组元素合并)

const friends = [{name: 'Anna',books: ['Bible', 'Harry Potter'],age: 21
}, {name: 'Bob',books: ['War and peace', 'Romeo and Juliet'],age: 26
}, {name: 'Alice',books: ['The Lord of the Rings', 'The Shining'],age: 18
}];const allBooks = friends.reduce((pre,curr)=>{return [...pre,...curr.books]},['superTiger_y'])console.log(allBooks)

Array.prototype.reduceRight

用法和reduce一样,只是遍历顺序相反,reduce是从左往右,reduceRight是从右往左

Array.prototype.indexOf(查找元素,并返回第一次出现的位置,不存在则返回-1)

indexOf()方法返回在数组中可以找到一个给定元素的第一个索引,如果不存在,则返回-1。

const beasts = ['ant', 'bison', 'camel', 'duck', 'bison'];console.log(beasts.indexOf('bison'));

Array.prototype.lastIndexOf(查找元素,并返回最后一个的位置,不存在则返回-1)

lastIndexOf() 方法返回指定元素在数组中的最后一个的索引,如果不存在,则返回-1。

const beasts = ['ant', 'bison', 'camel', 'duck', 'bison'];console.log(beasts.lastIndexOf('bison'));

Array.prototype.find(返回满足条件第一个元素的值)

find() 方法返回数组中满足提供的测试函数的第一个元素的值。否则返回 undefined。

const people = [{name:'super',age:20},{name:'tiger',age:19},{name:'_Y',age:22}
] const item= people.find(item => item.age === 19)
console.log('年龄等于19的元素:',item)const item1= people.find(item => item.age === 100)
console.log('年龄等于100的元素:',item1)

Array.prototype.findIndex (返回满足条件第一个元素的值的索引)

findIndex() 方法返回数组中满足提供的测试函数的第一个元素的值的索引。否则返回 -1

const people = [{name:'super',age:20},{name:'tiger',age:19},{name:'_Y',age:22}
] const index= people.findIndex(item => item.age === 19)
console.log('年龄等于19的元素的索引:',index)const index1= people.findIndex(item => item.age === 100)
console.log('年龄等于100的元素的索引:',index1)

看一遍都懂的数组遍历~确定不试试?相关推荐

  1. 看一遍就懂,详解java多线程——volatile

    多线程一直以来都是面试必考点,而volatile.synchronized也是必问点,这里我试图用容易理解的方式来解释一下volatile. 来看一下它的最大特点和作用: 一 使变量在多个线程间可见 ...

  2. [**奇文共赏**参考理解] 据说看五遍能懂的人智商 200

    转自琉璃鸟,下面是他的理解 李鱼 我被明明所救,至今已满千年.一千年前,明明从狐狸口中救下我时,我不过是条小蛇.她传我****之法,令我能幻化成人,赋我新生.从此,我便称呼她为"母亲&quo ...

  3. [**奇文共赏**补充问题] 据说看五遍能懂的人智商 200

    Question: (1)陈东吃了什么不该吃的东西? (2)陈东看到了什么不该看到的东西? (3)五星连珠意味着什么? (4)季胜为什么在信中说"我当见你" (5)"赠君 ...

  4. Electron 基础入门 简单明了,看完啥都懂了

    什么是 Electron? 介绍 使用 JavaScript, HTML 和 CSS 构建跨平台(Windows.MacOs.Linux)的桌面应用--这是Electron官网的简介 最初被GitHu ...

  5. 控制工程 留数法(看一遍就懂了)

  6. js 数组遍历方法详解(map、filter、find、findIndex、reduce)

    目录 前言 map map是什么 map方法的结构及入参 语法糖 map一般不改变原数组 filter 说明 例子 find 和 findIndex 说明 例子 reduce 说明 例子 尾言 前言 ...

  7. 【Day4】ES5(循环别名 ,数组,数组遍历,数组排序,二维数组)

    日期:2月3日 1. 循环的别名 别名: for () { } 别名: while() { } break   结束掉离他最近的循环 break 别名: 结束掉指定的循环 2. 循环的别名的使用场景 ...

  8. 云终端linux,云终端详细介绍,看完你就都懂了

    原标题:云终端详细介绍,看完你就都懂了 随着云计算技术的不断成熟和发展,云桌面被越来越多的人所熟知和使用,我们知道云桌面主要有云终端和服务器这两大硬件所组成.而今天我们要说的就是这个只有手机大小的云终 ...

  9. 爸爸!再不陪我,我就长大了!推荐每个爸爸都看一遍!

    http://mp.weixin.qq.com/s?__biz=MjM5ODQ2MTE2Mw==&mid=200272738&idx=7&sn=d18690ef0f63b16b ...

最新文章

  1. 使用K.function()调试keras
  2. 物联网安全:LED灯中存在多个安全漏洞
  3. 成人短信11条,全看懂的是超级色狼
  4. MAPGIS中输入分数和上下标格式的字符串。
  5. 搭建git服务器(权限管理)
  6. 网络15软工个人作业5——软件工程总结
  7. 雇员类(JAVA实现简单的类)
  8. 2021年下种子磁力最好用的网盘
  9. 蜂鸣器c语言相关程序,蜂鸣器c语言程序.doc
  10. 白开水最耐喝,最解内心的渴
  11. android 人脸 动画表情包,天呐 原来动画角色的面部表情是这样做出来的
  12. html将图片保存到文件夹,怎么把一张网页上的全部图片都保存到文件夹里
  13. 目标检测tricks(基于detectron2)
  14. 圆桌:满足客人空座需求,准备最少的椅子,合理安排客人入座圆桌
  15. 趣头条今日头条的视频何谓伪原创
  16. 十大编程语言黑客向,学会一个不怕没工作,全部学会随便秀操作
  17. 块级和图片的1px间隙
  18. centos7安装yearning
  19. TensorFlow2.x 常用知识
  20. Gluon-cv:安装使用以及目标检测算法样例

热门文章

  1. MT6261处理器规格介绍,MT6261芯片技术资料集锦
  2. 用python计算符号函数一元定积分和不定积分
  3. linux的的shell记忆
  4. 深度学习 端对端的车牌检测与识别 LPDR算法 License Plate Detection and Recognition CCPD
  5. css设置表格自动换行;table换行无效
  6. 三万字、91道MySQL面试题(收藏版)
  7. ◆2008 年广告创意设计师必备网址汇总◆
  8. Ubuntu14.04 安装 TP_LINK驱动 TL-WDN5200H 1.0无线网卡
  9. 《CSAPP》(第3版)答案(第三章)(一)
  10. 电脑连接信捷PLC方法