简介
今天吃 array-first 这个包,这个包主要是用来截取一个数组的头部元素的。
官方例子:
var first = require('array-first');
first(['a', 'b', 'c', 'd', 'e', 'f']);
//=> 'a'
first(['a', 'b', 'c', 'd', 'e', 'f'], 1);
//=> 'a'
first(['a', 'b', 'c', 'd', 'e', 'f'], 3);
//=> ['a', 'b', 'c']
目录结构
emm,觉得小包的目录结构都差不多的,略。
主要代码
var isNumber = require('is-number');
var slice = require('array-slice');
/**
* @param {Array<any>} arr 数组
* @param {number} num 截取数量
*/
module.exports = function arrayFirst(arr, num) {
if (!Array.isArray(arr)) {
throw new Error('array-first expects an array as the first argument.');
}
if (arr.length === 0) {
return null;
}
var first = slice(arr, 0, isNumber(num) ? +num : 1);
if (+num === 1 || num == null) {
return first[0];
}
return first;
};
代码相信各位都看得懂,而核心代码主要是 slice(arr, 0, isNumber(num) ? +num : 1);
这一句,而这其中用到了一个 array-slice 模块,这个模块跟 Array.splice 的作用一样,唯一区别是不会改变源数组,类似 String.splice。
单元测试
单元测试用的 mocha,测试脚本就不贴了,略。
总结
这个包比较小,但很符合包的定义:first,只截取头部的元素,美中不足的点是当 num 为1时,返回的是数组的第一个元素,这就导致返回的结果有可能是Array,也有可能是其他类型。但仔细想想,或许刚好就有这种使用场景吧~
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。