面试官: js中数组如何扁平化?

面试题如下:

1. es6提供的新方法 flat(depth)

let a = [1,[2,3]];  
a.flat(); // [1,2,3]  
a.flat(1); //[1,2,3]
复制代码

flat(depth) 方法中的参数depth,代表展开嵌套数组的深度,默认是1

其实还有一种更简单的办法,无需知道数组的维度,直接将目标数组变成1维数组。 depth的值设置为Infinity。

let a = [1,[2,3,[4,[5],{name:'zhangsan'}]]];  
a.flat(Infinity); // 结果见下图  a是4维数组
复制代码

2. for循环

var arr1 = [1, 2, 3, [1, 2, 3, 4, [2, 3, 4]]];
  function flatten(arr) {
    var res = [];
    for (let i = 0, length = arr.length; i < length; i++) {
      if (Array.isArray(arr[i])) {
        res = res.concat(flatten(arr[i])); //concat 并不会改变原数组
      } else {
        res.push(arr[i]);
      }
    }
    return res;
  }
  
  console.log(flatten(arr1));  //[1, 2, 3, 1, 2, 3, 4, 2, 3, 4]
复制代码

3. while循环

 var arr1 = [1, 2, [3], [1, 2, 3, [4, [2, 3, 4]]]];
  function flatten(arr) {
    while (arr.some(item => Array.isArray(item))) {
      arr = [].concat(...arr);
    }
    return arr;
  }
  flatten(arr1); //[1, 2, 3, 1, 2, 3, 4, 2, 3, 4]
复制代码

4.利用reduce 和 concat

var arr = [1,[2,[3,[4,5],6]]];
function flatten (arr) {
    return arr.reduce((pre, item) => Array.isArray(item) ? pre.concat(flatten(item)) : pre.concat(item) , [])
}
console.log(flatten(arr));  //[1, 2, 3, 4, 5, 6]
复制代码

转载于:https://juejin.im/post/5cc9894ff265da038733aef3

猜你喜欢

转载自blog.csdn.net/weixin_33711647/article/details/93175455