第一次遇到数组扁平化已经是在3k游戏的笔试题里,当时是用了递归的方法。因为对一些数组方法,字符串方法十分的不熟练
扁平化数组的核心都是,遍历数组元素,遇到数组就拆,不是数组就加进去。
var arr = [1, [2, 3, [4, 5]]]
console.log(bianpinghua(arr))
toString()+split()
先把数组转为字符串,然后通过,分割成数组,然乎字符转数字!太可以了这种方法!
function bianpinghua(arr){
arr = arr.toString().split(',').map((item)=>{
return parseInt(item)
})
return arr
}
reduce()+concat()
reduce()的第一项为累加的结果,item为数组每一项值。如果该项是数组,就递归,不是数组就直接连接。
function flatten(arr) {
return arr.reduce((result, item)=> {
return result.concat(Array.isArray(item) ? flatten(item) : item);
}, []);
}
还有es2019的新方法
flat(n)
const arr = [1, 2, [3, 4, [5, 6]]];
arr.flat(); // [1, 2, 3, 4, [5, 6]]
arr.flat(2); // [1, 2, 3, 4, 5, 6]
arr.flat (Infinity) //展开所有数组
不带参数则默认分解一层,带参数就解到n层,Infinity就是展开所有层级。
flat()方法还可以移除数组内的空项
网友评论