![](https://img.laitimes.com/img/_0nNw4CM6IyYiwiM6ICdiwiI0gTMx81dsQWZ4lmZf1GLlpXazVmcvwFciV2dsQXYtJ3bm9CX9s2RkBnVHFmb1clWvB3MaVnRtp1XlBXe0xCMy81dvRWYoNHLwEzX5xCMx8FesU2cfdGLwMzX0xiRGZkRGZ0Xy9GbvNGLpZTY1EmMZVDUSFTU4VFRR9Fd4VGdsYTMfVmepNHLrJXYtJXZ0F2dvwVZnFWbp1zczV2YvJHctM3cv1Ce-cGcq5CN2EjN3MTMhRTM3AjYhNzMzYzXzQTMwATM4IzLclDMyIDMy8CXn9Gbi9CXzV2Zh1WavwVbvNmLvR3YxUjLyM3Lc9CX6MHc0RHaiojIsJye.jpg)
需求:
多元數組=>一維數組
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種方式,你學會了嗎?