沐鳴下載_JS數組扁平化(flat)方法總結

需求:

多維數組=>一維數組 

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

第0種處理:直接的調用

arr.flat(Infinity);

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

第一種處理

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

第二種處理

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

第三種處理:遞歸處理

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);
    }
  }
}

第四種處理:用 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))

第五種處理:擴展運算符

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

站長推薦

1.雲服務推薦: 國內主流雲服務商,各類雲產品的最新活動,優惠券領取。地址:阿里雲騰訊雲華為雲

2.廣告聯盟: 整理了目前主流的廣告聯盟平台,如果你有流量,可以作為參考選擇適合你的平台點擊進入

鏈接: http://www.fly63.com/article/detial/7967