JS數組扁平化(flat)方法總結

需求:多維數組=>一維數組數組

let ary = [1, [2, [3, [4, 5]]], 6];
let str = JSON.stringify(ary);
複製代碼
//第0中處理:直接的調用
arr_flat = arr.flat(Infinity);
複製代碼
//第一種處理
ary = str.replace(/(\[|\])/g, '');
複製代碼
//第二種處理
str = str.replace(/(\[|\]))/g, '');
str = '[' + str + ']';
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(flatten(ary))
複製代碼
//第五種處理:擴展運算符
while (ary.some(Array.isArray())) {
  ary = [].concat(...ary);
}
複製代碼

這是一個比較實用並且很容易被問到的問題,歡迎你們交流補充。ui

相關文章
相關標籤/搜索