JS使用循环按指定倍数分割数组组成新的数组的方法

Posted 李初五

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JS使用循环按指定倍数分割数组组成新的数组的方法相关的知识,希望对你有一定的参考价值。

 今天一个新人同事问了我一个问题,就是有一个像下边这种不知道具体长度的数组,想以每4个为一组,重新组合为一个二维数组,很简单的需求只需要用到一个循环再去取余数就可以了,写了一个小demo在这里把代码包括注释贴出来供新人参考,代码如下:

        var chartArr = [
        {value:1,name:\'哈哈\'},
        {value:2,name:\'哈哈\'},
        {value:3,name:\'哈哈\'},
        {value:4,name:\'哈哈\'},
        {value:5,name:\'哈哈\'},
        {value:6,name:\'哈哈\'},
        {value:7,name:\'哈哈\'},
        {value:8,name:\'哈哈\'},
        {value:9,name:\'哈哈\'},
        {value:10,name:\'哈哈\'},
        {value:11,name:\'哈哈\'},
        {value:12,name:\'哈哈\'},
        {value:13,name:\'哈哈\'}
        ];
        var allData = []; //用来装处理完的数组
        var currData = []; //子数组用来存分割完的数据
        //循环需要处理的数组
        for(var i = 0; i < chartArr.length; i++) {
            //将chartArr[i]添加到子数组
            currData.push(chartArr[i]);
            console.log(i)
            //在这里求4的余数,如果i不等于0,且可以整除 或者考虑到不满4个或等于4个的情况就要加上  i等于当前数组长度-1的时候
            if((i != 0 && (i + 1) % 4 == 0) || i == chartArr.length - 1) {
                //把currData加到allData里
                allData.push(currData);
                //在这里清空currData
                currData = [];
            }
        };

下图是处理完的二维数组

 

以上是关于JS使用循环按指定倍数分割数组组成新的数组的方法的主要内容,如果未能解决你的问题,请参考以下文章

JS中,split()用法(将字符串按指定符号分割成数组)

JS中,split()用法(将字符串按指定符号分割成数组)

JS中,split()用法(将字符串按指定符号分割成数组)

将字符串按指定的符号分割为集合或数组

将字符串按指定的符号分割为集合或数组

将字符串按指定的符号分割为集合或数组