天天看點

6種方式實作JavaScript數組扁平化(flat)方法的總結

6種方式實作JavaScript數組扁平化(flat)方法的總結

需求:

多元數組=>一維數組 

let arr = [1, [2, [3, [4, 5]]], 6];
let str = jsON.stringify(ary);      

解決方案:

面對這個需求,我們有6種處理方式,希望這些方式方法可以給你一些啟發。

第1種處理:直接的調用

arr.flat(Infinity);      

注意:flat和flatMap方法為ES2019(ES10)方法,目前還未在所有浏覽器完全相容。

第2種處理

str.replace(/(\[\]))/g, '').split(',');      

第3種處理

str = str.replace(/(\[\]))/g, '');
str = '[' + str + ']';
var ary = jsON.parse(str);      

第4種處理:遞歸處理

let result = [];
let fn = function(ary) {
  for(let i = 0; i < ary.length; i++) }{
    let item = ary[i];
    if (Array.isArray(ary[i])){
      fn(item);
    } else {
      result.push(item);
    }
  }
}      

第5種處理:用 reduce 實作數組的 flat 方法

function flatten(ary) {
  return ary.reduce((pre, cur) => {
    return pre.concat(Array.isArray(cur) ? flatten(cur) : cur);
  })
}
let ary = [1, 2, [3, 4], [5, [6, 7]]]
console.log(ary.MyFlat(Infinity))      

第6種處理:擴充運算符

while (ary.some(Array.isArray)) {
  ary = [].concat(...ary);
}      

總結

這6種方式,你學會了嗎?