1、在文章的開(kāi)始先給大家介紹一下這兩者的共同點(diǎn),我們通常前者用的次數(shù)多一點(diǎn),比較常見(jiàn)
- 都是循環(huán)遍歷數(shù)組中的每一項(xiàng)
- 每一次執(zhí)行匿名函數(shù)都支持三個(gè)參數(shù),數(shù)組中的當(dāng)前項(xiàng)item,當(dāng)前項(xiàng)的索引index,原始數(shù)組input
- 匿名函數(shù)中的this都是指window
- 只能遍歷數(shù)組
2、關(guān)于forEach()
敲黑板:沒(méi)有返回值?。。。?/strong>
arr[].forEach(function(value,index,array){
xxxxx
})
- 參數(shù):value數(shù)組中的當(dāng)前項(xiàng),index當(dāng)前項(xiàng)的索引,array原始數(shù)組;
- 數(shù)組中有幾項(xiàng),那么傳遞進(jìn)去的匿名回調(diào)函數(shù)就需要執(zhí)行幾次
- 理論上這個(gè)方式是沒(méi)有返回值的,只是遍歷數(shù)組中的每一項(xiàng),不對(duì)原來(lái)數(shù)組進(jìn)行修改,但是可以自己通過(guò)數(shù)組的索引來(lái)修改原來(lái)的數(shù)組
舉例:
var array = [10,34,57,43,76];
var res = array.forEach(function (item,index,input) {
input[index] = item*10;
})
console.log(res);//--> undefined;
console.log(array);//--> 通過(guò)數(shù)組索引改變了原數(shù)組; [100,340,570,430,760]
3、關(guān)于map()
敲黑板:有返回值,可以return出來(lái)!?。?!
arr[].map(function(value,index,array){
xxx
return xxx
});
- 參數(shù):value數(shù)組中的當(dāng)前項(xiàng),index當(dāng)前項(xiàng)的索引,array原始數(shù)組
- 區(qū)別:map的回調(diào)函數(shù)中支持return返回值,return的是啥,相當(dāng)于把數(shù)組中的這一項(xiàng)變?yōu)樯叮ú⒉挥绊懺瓉?lái)的數(shù)組,只是相當(dāng)于把原數(shù)組克隆了一份,把克隆這一份的數(shù)組中的對(duì)應(yīng)項(xiàng)改變了 );
var array = [10,34,57,43,76];
var res = array.map(function (item,index,input) {
return item*10;
})
console.log(res); //[100, 340, 570, 430, 760]
console.log(array); //[10, 34, 57, 43, 76] 不變