数组扁平化
数组扁平化是指将一个多维数组变为一维数组
[1, [2, 3, [4, 5]]] ------> [1, 2, 3, 4, 5]
实现方法
方法一 es6提供的新方法 flat(depth) (性能最好,但有兼容问题)
利用 ES 6的最新语法,Array.prototype.flat()。缺点是,有兼容性问题。优点是非常简单。
mdn 上是这么描述的:flat() 方法会递归到指定深度将所有子数组连接,并返回一个新数组。
语法:var newArray = arr.flat(depth),参数说明:depth,可选,指定嵌套数组中的结构深度,默认值为1。
var arr1 = [1, 2, [3, 4]];
arr1.flat(); // [1, 2, 3, 4]
var arr2 = [1, 2, [3, 4, [5, 6]]];
arr2.flat(); // [1, 2, 3, 4, [5, 6]]不传参只会展开一层
var arr3 = [1, 2, [3, 4, [5, 6]]];
arr3.flat(2); // [1, 2, 3, 4, 5, 6] 传的参数为数组维度减一(3-1)
//Infinity展开所有嵌套数组
arr3.flat(Infinity); // [1, 2, 3, 4, 5, 6]
var arr4 = [1, 2, , 4, 5];
arr4.flat(); // [1, 2, 4, 5] flat()方法会移除数组中的空项
特殊说明:flat()方法会移除数组中的空项。但undefined、null仍会保留。
var arr = [1, 2, undefined , 4, 5, null];
arr.flat(); // [1, 2, undefined , 4, 5, null]

本文介绍了多种将多维数组转换为一维数组的方法,包括ES6的`flat()`、`replace`结合`split`、`join`与`split`、扩展运算符、`toString`与`split`、`reduce`以及递归方法。每种方法的特点和适用场景进行了详细阐述,特别是`flat()`方法在性能上最优,但存在兼容性问题。
最低0.47元/天 解锁文章
1090

被折叠的 条评论
为什么被折叠?



