一点通透:map与forEach的用法

简介: 一点通透:map与forEach的用法

map

map是什么?


map() 方法用于遍历一个数组,并且创建一个新数组,不会修改原数组,其结果是该数组中的每个元素是调用一次提供的函数后的返回值。

map() 是返回一个新数组,当你不使用返回新数组时,请使用forEach或for-of


怎么用?


首先map()里面必须要有一个回调函数functiong,这个回调函数就是用来处理调用的数据的

arr.map(function(){})


回调函数里可以传入三个参数,其中有一个是必须传入的(item,作为循环遍历数组的每一个数据的值),其他两个可以选择性的传入,index是索引下标

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


需要在回调函数内写return,返回数据

let arr = [1,2,3,4,5]
let newArr = arr.map((item,index)=>{
    // console.log(item) //1,2,3,4,5
    // console.log('index',index) //0,1,2,3,4
    return 2*item
})
console.log(newArr) //2,4,6,8,10

forEach

forEach是什么


forEach()  方法对数组的每个元素执行一次给定的函数。他不象map一样可以有返回值,不能使用

let newArr = arr.forEach(item=>{}) //这是错误的用法,newArr 是undefined

forEach与for循环一样,都是对数组进行遍历,forEach是对for(let i=0;i<arr.leng;i++){}的简写

用法


let arr = [1,2,3,4,5]
arr.forEach(item=>{
    console.log(item*2)
})
  • 正确:如果是基本数据类型,forEach不会改变原数组的值 ,如果是 引用数据类型,则会修改原数组的值
let arr2=[5]
arr2.forEach(item=>{
    item = item*2
})
console.log(arr2)  //[5]
let arr3=[{a:5}]
arr3.forEach(item=>{
    item.a = item.a*2
})
console.log(arr3) //[a:10]



目录
相关文章
|
6月前
|
JavaScript 前端开发 索引
问js的forEach和map的区别
JavaScript中的`forEach`和`map`都是数组迭代方法。`forEach`遍历数组但不修改原数组,无返回值;它接受回调函数处理元素。`map`则遍历数组并返回新数组,新数组元素为回调函数处理后的结果。两者都接收元素、索引和数组作为回调函数参数。
50 7
|
2月前
|
索引
ES5常见的数组方法:forEach ,map ,filter ,some ,every ,reduce (除了forEach,其他都有回调,都有return)
ES5常见的数组方法:forEach ,map ,filter ,some ,every ,reduce (除了forEach,其他都有回调,都有return)
|
5天前
|
存储 JavaScript
foreach和map
foreach和map
8 1
|
9天前
|
存储 JavaScript
foreach和map
foreach和map
6 1
|
2月前
|
存储 JavaScript 前端开发
`forEach()`方法和`map()`方法哪个执行效率更高?
`forEach()`方法和`map()`方法哪个执行效率更高?
|
2月前
数组方法中的`forEach()`方法和`map()`方法有什么区别?
数组方法中的`forEach()`方法和`map()`方法有什么区别?
|
2月前
|
JavaScript 前端开发
JavaScript 中 五种迭代数组的方法 every some map filter forEach
本文介绍了JavaScript中五种常用数组迭代方法:every、some、filter、map和forEach,并通过示例代码展示了它们的基本用法和区别。
|
3月前
|
JavaScript 前端开发 索引
JS中常用的数组迭代方法(filter,forEach,map,every,some,find,findIndex)
这段代码和说明介绍了JavaScript中数组的一些常用方法。函数接收三个参数:`item`(数组项的值)、`index`(项的位置,可选)和`array`(数组本身,可选)。示例展示了如何使用`filter()`过滤非空项、`forEach()`遍历数组、`map()`处理并返回新数组、`every()`检查所有元素是否满足条件、`some()`检查是否存在满足条件的元素、`find()`获取首个符合条件的元素值以及`findIndex()`获取其索引位置。这些方法都不会修改原数组。
JS中常用的数组迭代方法(filter,forEach,map,every,some,find,findIndex)
|
3月前
|
存储 算法 Java
Go 通过 Map/Filter/ForEach 等流式 API 高效处理数据
Go 通过 Map/Filter/ForEach 等流式 API 高效处理数据
|
4月前
|
JavaScript API
js【最佳实践】遍历数组的八种方法(含数组遍历 API 的对比)for,forEach,for of,map,filter,reduce,every,some
js【最佳实践】遍历数组的八种方法(含数组遍历 API 的对比)for,forEach,for of,map,filter,reduce,every,some
73 1