摘要:针对当对数据量庞大的数组执行遍历时,会相当耗费时间和内存,因为是单线程,因此在这个循环执行完之前会一直阻塞后面的代码执行,从而影响页面的渲染,逻辑绑定等等。这里讲下如何处理大数据的遍历的方法。
针对
当js对数据量庞大的数组执行遍历时,会相当耗费时间和内存,因为js是单线程,因此在这个循环执行完之前会一直阻塞后面的代码执行,从而影响页面的渲染,逻辑绑定等等。这里讲下如何处理大数据的遍历的方法。
原始方法遍历方法一般如下:
for(let i=0;i但是当面对庞大的数组时,上面代码执行的时间可能会相当长,下面来优化这个数组。
前提优化的前提是,需要满足下面两个条件
数据处理可以不同步运行
数据处理可以不按顺序进行
具体方法可以利用定时器去优化遍历数组,让遍历异步进行,这样就不会阻塞下面代码的执行,而且也可以正常遍历。具体代码如下:
function chunk (data) { setTimeout(function() { processData(data.shift()); if (data.length > 0) { setTimeout(arguments.callee, 100); } }, 100); }上面方法主要是利用data.shift获取数组中第一个元素的值,对这个值执行数据处理方法,并检查该数组是否有下一项,有的话利用callee继续执行该函数。这里的延时时间是100ms,可以根据具体的业务场景调整。这项技术叫做数据分块
方法优化由于某些处理程序需要带入上下文,因此可以将方法继续优化,如下:
function chunk (data, context) { setTimeout(function() { processData.call(context, data.shift()); if (data.length > 0) { setTimeout(arguments.callee, 100); } }, 100); }context 可以传也可以不传,举一个具体例子:
let arr = [1,2,3,4,5,6,7,8,9,10], nowTime = +new Date(); function processData (data) { console.log(data, +new Date() - nowTime); } function chunk (data, context) { setTimeout(function() { processData.call(context, data.shift()); if (data.length > 0) { setTimeout(arguments.callee, 100); } }, 100); } chunk(arr);打印的结果如下:
可以看出遍历是异步执行,执行间隔为100ms。注意:在这里是顺序执行的,但是如果间隔为0ms,并且数据处理程序需要执行很长时间时,就有可能导致遍历的方法不按顺序执行另外,shift方法是直接对原数组进行操作,所以如果不想要修改原数组时,可以传入原数组的拷贝。
let arr = [1,2,3,4,5,6,7,8,9,10], nowTime = +new Date(); function processData (data) { console.log(data, +new Date() - nowTime); } function chunk (data, context) { setTimeout(function() { processData.call(context, data.shift()); if (data.length > 0) { setTimeout(arguments.callee, 100); } }, 100); } chunk(arr.concat());这里利用了concat方法,生成了一个新数组,亦可以用extend等等,达到效果即可。
原文链接
the end.
3Fuyu
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/88312.html
摘要:报文用于协议交互的信息被称为报文。现在出现的各种首部字段及状态码稍后会阐述。状态码响应报文包含了多个范围的内容使用。如果服务器无法响应范围请求,则会返回状态码和完整的实体内容。 showImg(https://segmentfault.com/img/bVbthNL?w=900&h=500); http报文 用于HTTP协议交互的信息被称为HTTP报文。请求端的http报文叫做请求报文...
阅读 2699·2023-04-25 14:15
阅读 2625·2021-11-04 16:11
阅读 3373·2021-10-14 09:42
阅读 410·2019-08-30 15:52
阅读 2795·2019-08-30 14:03
阅读 3523·2019-08-30 13:00
阅读 2087·2019-08-26 11:40
阅读 3258·2019-08-26 10:25