有一个深层嵌套的数组,需要输出拍平后的新数组

const input = [1, [2, [3, 4], [5], [6]]];
const output = [1, 2, 3, 4, 5, 6];

实现方案 1:flat

const output = input.flat(Infinity);

这里为什么用无穷大呢,因为有的时候可能嵌套很深,我们没有精力去数,为了保证都能被打平,用一个最大的数字。

方案 2:递归

function flat(arr) {
var retVal = [];
for (var i = 0; i < arr.length; i++) {
if (Array.isArray(arr[i])) {
retVal = retVal.concat(flat(arr[i]));
} else {
retVal.push(arr[i]);
}
}
return retVal;
}
const output = flat(input);