JS数组扁平化

Posted 静谧coding

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JS数组扁平化相关的知识,希望对你有一定的参考价值。

JS实现将数组进行扁平化处理,即将多维数组展开为一维数组

方法一、递归

function flatten(arr){
    let result = [];
    for(let i=0;i<arr.length;i++){
        if(Array.isArray(arr[i])){
            result = result.concat(flatten(arr[i]));
        }
        else{
            result.push(arr[i]);
        }
    }
    return result;
}
 console.log(flatten([‘a‘, [‘b‘, ‘c‘, [7, 8]],[4,5,[6]]]))

方法二、arrary.reduce

function flatten2(arr) {
   return  arr.reduce((accumulator,currentValue)=>
         accumulator.concat(Array.isArray(currentValue) ? flatten2(currentValue) : currentValue),
        []);
}
console.log(flatten2([‘a‘, [‘b‘, ‘c‘, [7, 8]],[4,5,[6]]]));

考察升级:要求这个函数接受一个参数来确定扁平化深度

function flatten_deep(arr, deep) {
    let result = [];
    if (Array.isArray(arr) && deep > 0) {
        for (let i = 0; i < arr.length; i++) {
            result = result.concat(flatten_deep(arr[i], deep - 1));
        }
    }
    else {
        result.push(arr);
    }
    return result;
}

console.log(flatten_deep([‘a‘, [‘b‘, ‘c‘, [7, 8]],[4,5,[6,[‘dd‘,‘whidhw‘]]]],3));

  

以上是关于JS数组扁平化的主要内容,如果未能解决你的问题,请参考以下文章

JS数组扁平化

js 数组扁平化

手写一个JS函数,实现数组扁平化Array Flatten

js数组拍平(数组扁平化)的五种方式

-----js实现数组扁平化-----

JS如何实现数组扁平化?不同的方法有什么区别?