一点通透: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`则遍历数组并返回新数组,新数组元素为回调函数处理后的结果。两者都接收元素、索引和数组作为回调函数参数。
54 7
|
8天前
|
存储
`map()`方法在什么场景下会比 `forEach()`方法更高效?
综上所述,当需要对数组元素进行复杂的转换并生成新数组、进行链式调用和函数式编程、处理元素之间存在明确映射关系的情况以及与其他数组方法结合使用时,`map()`方法比`forEach()`方法更高效,能够使代码更加简洁、清晰和易于维护。
46 32
|
8天前
|
存储 JavaScript 前端开发
如何选择使用`map()`方法和`forEach()`方法?
选择使用`map()`方法还是`forEach()`方法主要取决于操作的目的、是否需要返回值、代码的可读性和维护性等因素。在实际开发中,需要根据具体的业务需求和场景来灵活选择合适的方法,以实现更高效、更易读和更易维护的代码。
14 3
|
2月前
|
索引
ES5常见的数组方法:forEach ,map ,filter ,some ,every ,reduce (除了forEach,其他都有回调,都有return)
ES5常见的数组方法:forEach ,map ,filter ,some ,every ,reduce (除了forEach,其他都有回调,都有return)
|
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
78 1