forEach() 和 map()的區(qū)別

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]  不變
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容