forEach map 和for
forEach 和for的区别
1.在固定长度或者长度不需要计算的时候for循环效率高于foreach,在不确定长度或者计算长度有损性能的时候用foreach比较方便
2.foreach适用于只是进行集合或数组遍历,for在较复杂的循环中效率更高。
3.如果对集合中的值进行修改,就要用for循环了。其实foreach的内部原理其实也是Iterator,但它不能像Iterator一样可以人为的控制,而且也不能调用iterator.remove();更不能使用下标来访问每个元素,所以不能用于增加,删除等复杂的操作。
4.forEach相比普通的for循环的优势在于对稀疏数组的处理,会跳过数组中的空位。
map /forEach
相同点
都是循环遍历数组中的每一项
forEach和map方法里每次执行匿名函数都支持3个参数,参数分别是item(每一项),index(索引值),arr(原数组)
匿名函数中的this都是指向window
只能遍历数组
都不会改变原数组
不同之处 :
map:
var arr = ['a',1,2,3,4,5]
var test = arr.map((item,index,arr)=>{
console.log(item,index)
return item
})
console.log(test)
// a 0
// 1 1
// 2 2
// 3 3
// 4 4
// 5 5
// [ 'a', 1, 2, 3, 4, 5 ]
1.map方法返回一个新的数组,数组中的元素为原始数组调用函数处理后的值。
2.map方法不会对空数组进行检测,map方法不会改变原始数组。
3.浏览器支持:chrome、Safari1.5+、opera都支持,IE9+,
4.若arr为空数组,则map返回的也是一个空数组
forEach:
var arr = ['a',1,2,3,4,5]
var test = arr.forEach((item,index,arr)=>{
console.log(item,index)
return item
})
console.log(test)
// a 0
// 1 1
// 2 2
// 3 3
// 4 4
// 5 5
// undefined
1.forEach方法用来调用数组的每个元素,将元素传给回调函数
2.forEach对于空数组是不会调用回调函数的。
3.不管arr是不是空数组 返回的都是undefined