兩者都是數(shù)組原型鏈中的方法廊蜒,方法是遍歷數(shù)組趴拧,回調(diào)函數(shù)對(duì)遍歷出來(lái)的對(duì)象進(jìn)行操作,但兩者的返回值有所不同
var kvArray = [{ key: 1, value: 10 },
{ key: 3, value: 20 },
{ key: 2, value: 30 }];
var mapResult = kvArray.map((v,i)=>{
return v.value = v.value + 's'
})
console.log(mapResult)// ['10s', '20s', '30s' ]
var filterResult = kvArray.filter((v,i)=>{
return v.value = v.value + 's'
})
console.log(filterResult) //[ { key: 1, value: '10ss' },{ key: 3, value: '20ss' },{ key: 2, value: '30ss' } ]
-
map
將返回值組裝成一個(gè)數(shù)組 -
filter
返回的也是一個(gè)數(shù)組山叮,但是返回的數(shù)組結(jié)構(gòu)與原數(shù)組結(jié)構(gòu)一致著榴,可以說(shuō)返回的數(shù)組是基于原數(shù)組的