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