数组是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()。
~完,我是刷碗智,我要去刷碗了,我们下期见!
有时候你会觉得很轻松很快乐,但有时候又会觉得好难,好像看不到希望。但我们必须接受生活似过山车的这个事实。不必羡慕别人,也不埋怨自己,脚踏实地,默默努力,做好该做的,剩下的就交给时间。 我今天在我们圈子里听到的一个同行的分享。它的很多客户呢,都是批量购买,甚至高峰时期会变成老客户反复购买,这种生意这...
因为比较受到环境限制,所以小城市可落地的项目真的不是很多,你会发现,小城市,人流基本都聚集在学校附近,或者景区附近,或者儿童游乐场,这些地方,并且大多数的孩子是由爷爷奶奶来照顾的,所以消费能力基本比较有限制,所以能落地的,就会较少了。 看市场 前面我们有说到过,小城市,基本都是爷爷奶奶在照顾...
对于不怎么用电脑的朋友来说,每天给自己的笔记本电脑开机两小时能可以让我们的电脑寿命更长,有很多朋友问windows10怎么设置定时开机?其实针对电脑windows10设置定时开机的方法还是比较简单的,那么win10电脑自动开机怎么设置呢?接下来小编给大家介绍电脑windows10系统设置定时...
炎炎夏日去上海旅游哪里好玩?除了外滩、东方明珠之外,今年暑期上海还有不少值得一去的新晋网红打卡地!不论是潮男潮女还是亲子带娃,都能找到适合自己的地方! ·上海天文馆:探索无垠宇宙的奥秘 天文迷们盼望已久的上海天文馆7月17日正式开馆!作为全球建筑规模最大的天文馆,绝对是近距离接...
企业主还没理解网络推广搭建概念吗?好比如高速公路需要搭建出来,才能通车收高速费,车才能快速通过吧。而企业主刚接触网络推广时,是如何计划打造seo网络推广团队的呢?先从这几个因素开 企业主还没理解网络推广搭建概念吗?好比如高速公路需要搭建出来,才能通车收高速费,车才能快速通过吧。 而企业主刚接触...
每一个个人站长都具有相当大的执行力和爆发力,能够几天不睡觉,开发一套网站程序,构架一个大型的网站;更能够一夜之间让什么都没有的网站内容无数。这样的速度和执行力在公司是没有的,只有我 每一个个人站长都具有相当大的执行力和爆发力,能够几天不睡觉,开发一套网站程序,构架一个大型的网站;更能够一夜之间让什...
寒露节气是在每年十月初,这个时候的天气会比较凉爽舒适,有些地区可能会有点冷,这个主要看各个地区的天气情况,大多数情况下,寒露过了之后,天气就会开始慢慢变冷,大多数地区都不会有高温天气了,有些地区还会有冷空气。2022寒露 寒露节气是在每年十月初,这个时候的天气会比较凉爽舒适,有些地区可能会有点冷,...
一到换季,每个人的身体就会反射一些情况出来,而免疫力比较差的朋友们,就有可能会在嘴唇部分长出疱疹。那么,嘴唇疱疹过后为什么刺痛肿胀?为啥疱疹过后嘴肿消不下去?一起来看看久久派带来的详细介绍吧!嘴唇疱疹过后为什么刺痛肿胀 一到换季,每个人的身体就会反射一些情况出来,而免疫力比较差的朋友们,就有可能会...
很多网友表示iPhonexsmax原相机拍照模式可以吊打所以系列,很多人把xsmax留着也只是为了拍照。目前,轻颜相机更新了xsmax原相机模式,大家可以直接在里面寻找并进行拍照哦!轻颜相机xsmax原相机模式在哪1、当 很多网友表示iPhonexsmax原相机拍照模式可以吊打所以系列,很多人把x...
深圳南山好玩的地方 1 欢乐海岸 景区简介: 快乐海岸总面积约125万平方米,其中水域面积近一半。总的来说,快乐海岸最大的特点就是以水为魂。 深圳市十大著名旅游景点? 景区亮点: 快乐海岸汇聚全球大师智慧,以海洋文化为主题,以生态环境保护为理念,以创新商业为主体,以创造城市滨海健...
奥粒绒作为时下较为火热的面料之一,想必大家再逛直播间和小红书的时候都有它的推荐,但由于时下就冬天越来越近,很多友友都好奇奥粒绒冬天穿保暖吗,小面小编就和大家一起看看奥粒绒能穿到几度。奥粒绒冬天穿保暖吗奥粒绒的保暖性还是比 奥粒绒作为时下较为火热的面料之一,想必大家再逛直播间和小红书的时候都有它的推...
窦性心律不齐是心脏的一种表现,这个是属于正常的,大家也不用太担心,这和自己的心理情况也有很大的关系。那么,窦性心律不齐会引起胸闷气短呼吸困难吗?窦性心律不齐有什么危害?一起来看看久久派带来的详细介绍吧!窦性心律不齐会引 窦性心律不齐是心脏的一种表现,这个是属于正常的,大家也不用太担心,这和自己的心...
最近刚买了一部红米手机,但是通过数据线连接电脑时确显示无法识别的USB,打开USB调试后仍然无法连接电脑。最后琢磨了很长时间才解决了问题,下面我将解决问题的方法分享给大家,希望能够帮到你。 操作方法 01手机打开USB调试模式,并通过手机数据线连接到电脑。 02在手机上安装QuickS...
什么材质防静电,防静电用什么。小编带你了解更多相关信息。 1、防静电材料有防静电有机玻璃板(防静电亚克力板)、防静电PVC板(防静电聚氯乙烯板)、防静电PC板(防静电聚碳酸酯板)、防静电PET板(聚对苯二甲酸二乙酯)、防静电尼龙板(MC501CDR6)等。 2、防静电材料是指在同种材料或其他...
红薯的吃法比较多,烤着吃就是其中比较受欢迎的一种吃法,很多人都会在家烤红薯吃,尤其是女性朋友们。烤红薯吃起来会比较甜,这个主要是因为在高温下里面的淀粉生成麦芽糖和葡萄糖等,并不是加了糖精,也不是放糖水里面泡了的。烤红薯太 红薯的吃法比较多,烤着吃就是其中比较受欢迎的一种吃法,很多人都会在家烤红薯吃...