数组扁平化

什么是数组扁平化?

数组扁平化就是将一个多维数组转换为一个一维数组

实现思想

1、对数组的每一项进行遍历。

2、判断该项是否是数组。

3、如果该项不是数组则将其直接放进新数组。

4、是数组则回到1,继续迭代。

5、当数组遍历完成,返回这个新数组。

实现代码

Array.prototype.flatten = function () {
  var resultArr = [];
  var len = this.length;
  for (var i = 0; i < len; i ++) {
    if (Array.isArray(this[i])) {
        resultArr = resultArr.concat(this[i].flatten());
    } else {
      resultArr.push(this[i]);
    }
  }
  return resultArr;
}

使用reduce方法

Array.prototype.flatten = function () {
  return this.reduce(function (prev, cur, curIndex, arr) {
      return Array.isArray(cur) ? prev.concat(cur.flatten()) : prev.concat(cur); 
  }, []);
}

使用ES6进一步简化

const flatten = arr => arr.reduce((prev, next) => Array.isArray(next) ? prev.concat(flatten1(next)) : prev.concat(next), []);

你可能感兴趣的:(数组扁平化)