• 实现把多维数组转为一维数组的几种方式


    在开发过程中遇到一个比较ip大小的情况,并且遇到了把二维数组转为一维数组的情况,翻下资料,做下总结。

    方法一:转字符串法

    该例子中,tempArr是一个多维数组,使用join将其转为字符串,在使用split方法转换为一维数组。

    缺点: 如果数组中的各个项是number,将不可避免的转为字符串。

        /** 
         * 使用转字符串法
         */
        let tempArr = [1,[2,3],[4,5,[6,7]]];
        let result_str1 = tempArr.join(',').split(',');
        console.log(result_str1); //  ["1", "2", "3", "4", "5", "6", "7"]

    改进:

    使用了map进行再次遍历。

    这种情况只适用于数组中各个项都是number类型或string类型的情况

        // 可以使用循环改进
        function unid(arr){
            let result_str1 = arr.join(',').split(',');
            let result_number = result_str1.map(item=>{
                return Number(item);
            });
            return result_number;
        }
        console.log(unid(tempArr)); // [1, 2, 3, 4, 5, 6, 7]

    方法二:使用数组的concat方法,以及apply 

    我们知道concat方法参数如果是一个数组,会把一个一维数组转为单个的项和前面的数组链接起来,如果是多维数组,则保留多维数组里面的项。

    看下面这个小例子:

        // 数组的concat方法
      
      let tempArr2 = ['3',4],
      tempArr3 = ['3',4,[5,6]];
      console.log([1,2].concat(tempArr2)); // [1, 2, "3", 4]
      console.log([1,2,].concat(tempArr3)); // [1, 2, "3", 4, [5,6]]

    所以使用concat方法只能把二维数组转为一维数组

        let tempArr4 = [[1,2],'3','4',[5,6],[7]];
        console.log([].concat.apply([],tempArr4)); // [1, 2, "3", "4", 5, 6, 7]

    方法三:使用递归

    可以使用Object.prototype.toString.call()来判断array的类型,也可以使用Array.isArray来判断。

        // 方法三:使用递归来实现多维数组转为一维数组
        let result = [],
            tempArr5 = ['1',2,[3,4,[5,6]],7];
        function unid1(arr){
            for(let item of arr){
                if(Object.prototype.toString.call(item).slice(8, -1)==='Array'){
                    unid1(item);
                }else{
                    result.push(item);
                }
            }
            return result;
        }
        console.log(unid1(tempArr5)); // ["1", 2, 3, 4, 5, 6, 7]

    三种方法有好有坏,还是需要根据实习情况来按需使用。

  • 相关阅读:
    附加数据库报错:无法打开物理文件 XXX.mdf",操作系统错误 5:"5(拒绝访问。)"
    Java(TM) SE Development Kit 6 卸载不掉怎么办
    (转)WCF入门教程(一)简介
    (转)SQL Server 2008怎样编辑200行以上的数据
    远程桌面下如何打开任务管理器
    在 sys.servers 中找不到服务器的解决办法,自己解决的
    MySQL 8小时问题
    Spring 事件机制
    MapReduce架构
    HDFS架构
  • 原文地址:https://www.cnblogs.com/chinabin1993/p/9761141.html
Copyright © 2020-2023  润新知