【数组扁平化】Js中数组扁平化的方法

扁平化

层叠的多维数组转换为一维数组的过程成为数组的扁平化

1.调用ES6的flat方法

Infinity: 参数,指定合并的层级。例:1,则合并1和2,后面的数组正常

let list = [ 1 , [ 2 ] , [ 3 , 4 , [ 5 , 6 ] ] ]

let newList = list.flat(Infinity)
console.log(newList)
// [1 , 2 , 3 , 4 , 5 , 6 ]
2.普通递归
let list= [1, [2, [3, [4, 5]]],6];
 
let result= [];
let fn=function(list) {
    for(let i=0; i<list.length; i++) {
        let item=list[i];
        if (Array.isArray(list[i])){
            fn(item);    
        } else {
            result.push(item);    
        }  
    }
};
fn(list);
console.log(result);
// [1, 2, 3, 4, 5, 6]
3.扩展运算符
let list= [1, [2, [3, [4, 5]]],6];
while (list.some(Array.isArray)) {
    // 将多维数组逐渐展开拼接
    list=[].concat(...list);
};
console.log(list);
// [1, 2, 3, 4, 5, 6]

你可能感兴趣的:(JavaScript,javascript,前端)