本文共 1415 字,大约阅读时间需要 4 分钟。
Array.prototype.flat
是数组扁平化方法,按照一个指定的深度递归遍历数组,并将所有元素与遍历到的子数组中的元素合并为一个新数组返回。
let newArray = arr.flat([depth])
depth
参数指定要提取嵌套数组的结构深度,默认值为 1
,即展开一层;若要展开两层,可以传 2
;如需要展开任意深度的嵌套数组,可以使用 Infinity
。
let arr = [1, 2, [3, 4, [5, 6]]];// 不传或者传1都只展开一层arr.flat(); // [1, 2, 3, 4, [5, 6]]arr.flat(1); // [1, 2, 3, 4, [5, 6]]// 展开指定深度arr.flat(2); // [1, 2, 3, 4, 5, 6]// 传入0或者负值不进行展开,只是浅拷贝arr.flat(0); // [1, 2, [3, 4, [5, 6]]]let arr2 = [1, 2, [3, 4, [5, 6, [7, 8, [9, 10]]]]];// 展开任意深度arr2.flat(Infinity); // [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
Infinity 跟 NaN 一样也是属于 number 类型
Array.prototype.flatMap
方法首先使用 map
函数映射数组的每个元素,然后再为每个元素调用一下 flat
函数,相当于先 map
后 flat
。
var new_array = arr.flatMap(function callback(currentValue[, index[, array]]) {
// return element for new_array }[, thisArg])
let arr = [1, 2, 3, 4];// 使用 flatMaplet arr1 = arr.flatMap(x => [x * 2]); // [2, 4, 6, 8]// 相当于调用 map 后调用 flatlet arr1 = arr.map(x => [x * 2]); // [[2], [4], [6], [8]]arr2 = arr1.forEach(x => x.flat()); // [2, 4, 6, 8]
注意一下,很多人看到 flatMap
,以为是先 flat
后 map
,但事实上是先 map
后 flat
,我们可以测试一下:
[1, 2, [3], 4].flatMap(x => x + 1);// [2, 3, "31", 5]
很明显,
flatMap
是先执行了map
,中间那个"31"
是因为数组与数字相加时,数组自动调用了toString()
方法。
根据上面的分析,我们可以简单实现一下 faltMap
方法:
Array.prototype.flatMap = function(mapper) { return this.map(mapper).flat();}// flat 方法可以这样实现const flat = (arr) => arr.reduce((a, b) => a.concat(b), []);
参考:
转载地址:http://ptye.baihongyu.com/