数组是JavaScript编程中最常用的结构之一,这也是为什么了解它的内置方法很重要。
在本文中,我们研究一下如何在 JS 中将数组拆分为n个大小的块。
具体来说,主要研究两种方法:
slice()方法是提取数组块,或者将其切成块的最简单方法:
slice(start, end) 方法返回一个新的数组对象,这一对象是一个由 begin 和 end 决定的原数组的浅拷贝(包括 begin,不包括end)。原始数组不会被改变。
注意:start和end都可以是负整数,这仅表示它们是从数组末尾枚举的。-1是数组的最后一个元素,-2是倒数第二个,依此类推…
因此,要将列表或数组分割成偶数块,我们使用slice()方法
function sliceIntoChunks(arr, chunkSize) {
const res = [];
for (let i = 0; i < arr.length; i += chunkSize) {
const chunk = arr.slice(i, i + chunkSize);
res.push(chunk);
}
return res;
}
const arr = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10];
console.log(sliceIntoChunks(arr, 3));
运行结果:
[[ 1, 2, 3 ], [ 4, 5, 6 ], [ 7, 8, 9 ], [ 10 ]]
在上面的代码中,我们通过遍历数组并按每个chunkSize对其进行切片,将arr分解成大小为3的小块。在最后一次迭代中,只剩下一个元素(10),所以它自己就组成一个块。
即使splice()方法看起来与slice()方法相似,但其用法和副作用却大不相同。我们仔细来看看:
// splice 做以下两件事:
// 1. 删除从 startIdx 开始的 deleteCount 元素
// 2. 将提供的新元素(newElem1, newElem2…)插入到myArray中,以索引startIdx开始
// 该方法的返回值是一个包含所有已删除元素的数组
myArray.splice(startIdx, deleteCount, newElem1, newElem2...)
let arrTest = [2, 3, 1, 4]
let chunk = arrTest.splice(0,2)
console.log(chunk) // [2, 3]
console.log(arrTest) // [1, 4]
我们通过一个代码示例来实际了解这一点:
function spliceIntoChunks(arr, chunkSize) {
const res = [];
while (arr.length > 0) {
const chunk = arr.splice(0, chunkSize);
res.push(chunk);
}
return res;
}
const arr = [1, 2, 3, 4, 5, 6, 7, 8];
console.log(spliceIntoChunks(arr, 2));
运行结果:
[ [ 1, 2 ], [ 3, 4 ], [ 5, 6 ], [ 7, 8 ] ]
在这里,我们使用while循环遍历数组。在每次迭代中,我们执行拼接操作,并将每个块添加到结果数组中,直到原始数组中不再有其他元素为止(arr.length> 0)。
需要注意的非常重要的一点是splice()会更改原始数组。如slice()创建原始数组的副本,因此原始数组不会有任何更改。
在本文中,我们介绍了在 JS 中将列表分割为多个块的几种简单方法。在此过程中,我们学习了如何使用几个内置的数组方法,如slice()和splice()。
就像组织严密的现代黑帮一样,,黑客们同样拥有复杂精巧的产业链,每天在全球黑产网络中流转的交易额数以亿计,整体规模更难以估测。 但其中每个黑客的具体收入如何?黑客是如何进行攻击准备的?他们是如何进行内部交易的,并遵循某些规则不相互越界呢? 一些安全研究者长期潜伏在地下黑产网络中,近距离观察其运...
拆分了一下鹅厂工资构成,根据岗位和水平,基本工资再19k-22k,18薪,每个月房补4k,股票也是分等级6-22万,分两年发,签字费3w。这样算下来,低的有40万,高的有60万。上管拿40万的这种叫白菜价; 有以下几方面的原因: 1、最需要的不是经验,而是创新。 比如金融、地产行...
1,568A网络电缆颜色顺序: 首先剥开网络电缆,然后从左到右排列顺序:白绿色,绿色,橙色,蓝色,白色蓝色,橙色,白色棕色和棕色。 2、568B网线颜色顺序: 剥开网络电缆并从左到右排列顺序:白色橙色,橙色,白色绿色,蓝色,白色蓝色,绿色,白色棕色,棕色。...
正文:现在大家都在谈创业,可是创业也是需要很多资金投入的,从当前形式来看,普通创业者根本就不合适大规模投资,因为现在是信息社会,不是刚改革开放那会,只要有胆量,随便做点生意都能赚大 正文:现在大家都在谈创业,可是创业也是需要很多资金投入的,从当前形式来看,普通创业者根本就不合适大规模投资,因为现在...
空调加氟的需求很大,家里一到夏天,为了保证空调的好效果,可能会加好几次氟利昂。大家对空调加氟的价格也是很关注,空调加氟一般需要多少钱?小啄以格力空调加氟一般多少钱为例给大家聊聊吧~ 空调加氟的需求很大,家里一到夏天,为了保证空调的好效果,可能会加好几次氟利昂。大家对空调加氟的价格也是很关注,空调加...
多数人去养君子兰就是为了看它开花,让它的叶片长的宽大油亮,不会黄叶,在家中观赏才会更漂亮,但是自己去买回来养的过程中,要么叶片长得不好,要么到了花期不开花,根本就养不好君子兰。现在 多数人去养君子兰就是为了看它开花,让它的叶片长的宽大油亮,不会黄叶,在家中观赏才会更漂亮,但是自己去买回来养的过程中...
闲鱼是阿里巴巴旗下闲置交易平台。使用淘宝或支付宝账户登录,无需经过复杂的开店流程,即可达成包括一键转卖个人淘宝账号中“已买到宝贝”、自主手机拍照上传二手闲置物品、以及在线交易等诸多 闲鱼是阿里巴巴旗下闲置交易平台。使用淘宝或支付宝账户登录,无需经过复杂的开店流程,即可达成包括一键转卖个人淘宝账号中...
微信拥有10亿用户,日活用户达8亿,可以说在中国除了小孩和老人不会用智能手机而没有使用微信之外,其他的中国人手机里应该都安装了微信。流量在哪里,生意就在哪里,这是所有做生意的老板都 微信拥有10亿用户,日活用户达8亿,可以说在中国除了小孩和老人不会用智能手机而没有使用微信之外,其他的中国人手机里应...
一、市场调研——买家角色的定义在深入研究你所在行业的客户如何做出购买决定之前,你必须首先了解他们是谁。这就是你的买家角色派上用场的地方。买家角色(有时称为营销角色)是理想客户的虚构 一、市场调研——买家角色的定义 在深入研究你所在行业的客户如何做出购买决定之前,你必须首先了解他们是谁。这就是你的...
武汉公积金最高额度有所调整啦!首套房最高贷款额度可以达到90万,不过是纯公积金,商转公的话并不支持哦!那么,武汉公积金最高额度90万维持多久?一起来看看久久派带来的详细介绍吧!武汉公积金额度90万支持商转公吗不支持,只支 武汉公积金最高额度有所调整啦!首套房最高贷款额度可以达到90万,不过是纯公积...
胡萝卜白萝卜一起有毒 胡萝卜和白萝卜可以一起吃吗? 自古以来就有萝卜上街,药店停歇、十月萝卜小人参,冬食萝卜夏吃姜,不劳医生开处方等说法。这些也足以让我们知道白萝卜在饮食中的重要性。那白萝卜到底有什么作用呢?先分析一下白萝卜的营养价值。白萝卜营养分析:白萝卜不含脂肪,主要由蛋白质...
破壁机怎么打豆浆步骤 当许多朋友使用破壁机制作豆浆时,他们发现会有很多泡沫。这是因为大豆中的蛋白质与水结合形成蛋白质胶体,增加了水的张力。在破壁机的不断搅拌过程中,产生了大量的泡沫。这些泡沫中含有蛋白质胶体,因此不容易破裂。本文主要研究泡沫的原理。 破壁机打豆浆沫太多? 当谈到豆...
薯片里面的气体是氮气,这种是健康无害的,没有气味,可以放心食用,不需要担心哦!那么,薯片吃多了对身体有什么危害?一起来看看久久派带来的详细介绍吧!薯片里面的气体是什么气体芯片中的气体是氮气。氮清洁、无毒、干燥。可以防止 薯片里面的气体是氮气,这种是健康无害的,没有气味,可以放心食用,不需要担心哦!...
茭白是生活中比较常见的一种蔬菜,它的吃法比较多,大多数人都会炒着吃,这样吃起来会比较香,茭白可以和各种各样的食材炒着吃,比如牛肉、猪肝、芹菜以及番茄等,不仅好吃,还比较有营养。茭白炒什么最好吃最有营养1.茭白+牛肉:催乳 茭白是生活中比较常见的一种蔬菜,它的吃法比较多,大多数人都会炒着吃,这样吃起...
土豆保存方法和注意事项,怎么保存土豆。小编带你了解更多相关信息。 1、保温袋保存法:准备一个干净的保温袋把土豆直接装入保温袋里面,并将其密封起来,这里要注意的是,土豆在保存的时候,千万不要去对接进行清洗,而是直接带泥土保存,这是土豆保存时间长久的关键。 2、冷冻保存法:相比较于保温袋保存法的...