zoukankan      html  css  js  c++  java
  • js中数组扁平化处理

    js中数组扁平化处理

    经典面试题,项目中可以用到js数组操作的地方很多,js数组扁平化是其中一种

    什么是数组扁平化?

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

    实现的基本方式

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

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

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

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

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

    实现数组扁平化代码

    1.常规方式 递归处理

    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;
    }
    var arr=[1,2,3,[4,5,'hello',['world',9,666]]]
    console.log(arr.flatten())//[1, 2, 3, 4, 5, "hello", "world", 9, 666]
    
    

    2.使用reduce方法

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

    3. yield*的用法,天才级别的扁平化方式

    function* iterTree(tree){
          if(Array.isArray(tree)){
              for(let i = 0 ;i<tree.length;i++){
                  yield* iterTree(tree[i]);
              }
          }else{
              yield tree;
          }
      }
     let arr1 = [1, 2, ['a', 'b', ['中', '文', [1, 2, 3, [11, 21, 31]]]], 3];
      let list=[]
    for (const x of iterTree(arr1)) {
        list.push(x)
      }
      console.log(list);//[1, 2, "a", "b", "中", "文", 1, 2, 3, 11, 21, 31, 3]
    
    

    4. es6中的flat函数也可以实现数组的扁平化

    let arr1 = [1,2,['a','b',['中','文',[1,2,3,[11,21,31]]]],3];
     console.log( arr1.flat( Infinity ) ); 
    
    

    5.扩展运算符

    //ES6 增加了扩展运算符,用于取出参数对象的所有可遍历属性,拷贝到当前对象之中:
    
    var arr = [1, [2, [3, 4]]];
    console.log([].concat(...arr)); // [1, 2, [3, 4]]
    //我们用这种方法只可以扁平一层,但是顺着这个方法一直思考,我们可以写出这样的方法:
    
    // 改进
    var arr = [1, [2, [3, 4]]];
    
    function flatten(arr) {
    
        while (arr.some(item => Array.isArray(item))) {
            arr = [].concat(...arr);
        }
    
        return arr;
    }
    
    console.log(flatten(arr))
    
    
  • 相关阅读:
    nginx 代理概念理解
    nginx反向代理(proxy_pass)tomcat的过程中,session失效的问题解决
    Mybatis-Generator 详解 http://www.cnblogs.com/jtzfeng/p/5254798.html
    web容器线程数和程序中线程阻塞导致 请求超时
    教程-Delphi操作快捷键
    PC-博客首页中增加必应或GOOGLE搜索功能
    PC-大概最全的黑客工具表了
    PC-计算机动行命令里的密密!系统管理程序!
    PC-红警联机问题与下载
    PC-破解RAR软件注册问题
  • 原文地址:https://www.cnblogs.com/luckyjiu9/p/13649265.html
Copyright © 2011-2022 走看看