map和flatMap的区别

返回值
map 返回一个新数组,该数组的元素是通过对原始数组的每个元素应用回调函数的结果而创建的。
flatMap 也返回一个新数组,但是在应用回调函数之后,它会将结果扁平化为一个新数组。如果回调函数返回一个数组,flatMap 会将这个数组的元素插入到新数组中。

处理嵌套数组
map 会保留嵌套数组的结构,即使回调函数返回数组。
flatMap 会将嵌套数组扁平化为一个新数组。

示例

let numbers = [1, 2, 3, 4];

let mappedResult = numbers.map((num) => [num, num * 2]);

console.log(mappedResult);
// 输出:[[1, 2], [2, 4], [3, 6], [4, 8]]
let numbers = [1, 2, 3, 4];

let flatMappedResult = numbers.flatMap((num) => [num, num * 2]);

console.log(flatMappedResult);
// 输出:[1, 2, 2, 4, 3, 6, 4, 8]
posted @ 2024-01-17 11:18  Hishine  阅读(935)  评论(0)    收藏  举报