array-chunk

423 阅读1分钟

将数组(array)拆分成多个 size 长度的区块,并将这些区块组成一个新数组。 如果array 无法被分割成全部等长的区块,那么最后剩余的元素将组成一个区块。

参数

  1. array  (Array) : 需要处理的数组
  2. [size=1]  (number) : 每个数组区块的长度

返回

(Array) : 返回一个包含拆分区块的新数组(注:相当于一个二维数组)。

demo

 * chunk(['a', 'b', 'c', 'd'], 2)
 * // => [['a', 'b'], ['c', 'd']]
 *
 * chunk(['a', 'b', 'c', 'd'], 3)
 * // => [['a', 'b', 'c'], ['d']]
 

个人实现

    function chunk(array, size) {
     let res = [];
     for(let i = 0 ; i<= array.length; i += size) {
         res.push(array.slice(i, i + size));
     }
     return res;
   }
   chunk(['a', 'b', 'c', 'd'], 3);

源码

/**
* Creates an array of elements split into groups the length of `size`.
* If `array` can't be split evenly, the final chunk will be the remaining
* elements.
*
* @since 3.0.0
* @category Array
* @param {Array} array The array to process.
* @param {number} [size=1] The length of each chunk
* @returns {Array} Returns the new array of chunks.
*/
function chunk(array, size = 1) {
 size = Math.max(toInteger(size), 0) // 取整,最小为零
 const length = array == null ? 0 : array.length
 if (!length || size < 1) {
   return []
 }
 let index = 0
 let resIndex = 0
 // 向上取整,创建结果数组
 const result = new Array(Math.ceil(length / size))

 while (index < length) {
   result[resIndex++] = slice(array, index, (index += size))
 }
 return result
}