lodash源码透视01:_.chunk

两年前三年前的今天我分享了一篮子"绝妙创意",后续果然啥都没干...

好,现在开始救赎!今天我们开始lodash源码透视第一期之 _.chunk。

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

举两个例子:

聪慧的你一定看出来了,入参有俩,第一个传入源数组originArr,第二个参数chunkLength表示每一份的长度,非常符合直觉。

返回的就是切分好的子数组组成的一个数组。

假如让我实现这个方法(写这句话的时候我真的没看过源码),我会怎么做呢?

step1 数组长度整除分片数(originArr/chunkLength),得到一个结果chunkCount

  • 如果数组长度取余分片数(originArr%chunkLength)大于0,那么份数就是chunkCount = chunkCount + 1;

  • 如果数组长度取余分片数(originArr%chunkLength)等于0,那么份数就是chunkCount = chunkCount;

step2 写一个循环,用split方法把数组分成chunkCount份,输出结果,结束。

用JS代码表达如下:

上面是我的盲猜,实际lodash中是如何实现这个函数的呢?

下方是我从lodash代码库中复制出来的chunk的实现。

js 复制代码
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;
}

可以看出,实现的思路跟我的基本一致,也是使用一次循环实现了功能,但是健壮性和代码简洁程度比我强了好多。

  1. 函数开始对array和size的异常情况做兜底处理。

  2. 获取输出chunk个数的方式也比我的简洁优雅(我的三目表达式真的臃肿)。

  3. 异常情况提前返回,实际执行代码行数比我的少。

  4. 历久弥新的函数库,有许多通用的函数做了抽离复用。

  5. 参数命名方面,虽然可以依赖后期混淆减少代码量,但是作用域有限,代码规模可控的情况下,其实可以简短抽象一些。

一个小小的工具函数,可以看出一群人一起迭代之后的最终效果,比起我拍脑袋想出来的解法强出了几个身位!!

欢迎关注我,指点我~​

相关推荐
IT_陈寒3 分钟前
Java 21虚拟线程实战:7个性能翻倍的异步重构案例与避坑指南
前端·人工智能·后端
锅挤3 分钟前
Vue2:小水一下(5)
前端·javascript·html
翻斗花园岭第一爆破手4 分钟前
flutter2:Container的简介与尺寸
java·服务器·前端
倔强的小石头_12 分钟前
Python 从入门到实战(十四):Flask 用户认证(给 Web 应用加安全锁,区分管理员与普通用户)
前端·python·flask
be or not to be16 分钟前
前端基础实战笔记:文档流 + 盒子模型
前端·笔记
程序员码歌17 分钟前
短思考第264天,每天复盘5分钟,胜过你盲目努力1整年(2)
前端·后端·ai编程
nono牛18 分钟前
实战项目:设计一个智能温控服务
android·前端·网络·算法
敲敲了个代码7 小时前
从硬编码到 Schema 推断:前端表单开发的工程化转型
前端·javascript·vue.js·学习·面试·职场和发展·前端框架
dly_blog9 小时前
Vue 响应式陷阱与解决方案(第19节)
前端·javascript·vue.js
消失的旧时光-19439 小时前
401 自动刷新 Token 的完整架构设计(Dio 实战版)
开发语言·前端·javascript