javascript性能优化之分时函数的介绍
程序员文章站
2022-03-14 18:48:08
分时函数和函数节流的问题不一样,函数节流针对的事件不是用户主动调用的,前面已经提过了。
函数节流的原理是:延迟当前函数的执行,如果该次延迟还没有完成,那么忽略接下来...
分时函数和函数节流的问题不一样,函数节流针对的事件不是用户主动调用的,前面已经提过了。
函数节流的原理是:延迟当前函数的执行,如果该次延迟还没有完成,那么忽略接下来该函数的请求。也就是说会忽略掉很多函数请求。
在一些开发场景中,我们可能会一次性向文档中注入上千个节点,在短时间内向浏览器中大量添加dom节点可能会让浏览器吃不消,结果往往会让浏览器卡顿或吃不消,解决方案之一便是使用分时函数(timechunk)。
timechunk分时函数让创建节点的工作分批进行,比如一秒钟创建1000个节点,改为每个200ms创建10个节点。具体timechunk函数封装如下:
function timechunk( arr, fn, count){//arr 数组 fn操作函数 count每次操作数量 var obj, t; var start = function(){ var len = math.min(count||1,arr.length); for(var i=0; i < len; i++){ obj = arr.shift(); fn(obj) } }; return function(interval){ t = setinterval(function(){ if(arr.length==0){ return clearinterval(t) }; start(); },interval||200) } }
应用:
加入我们要在文档中添加1000个节点,可以利用timechunk分时函数每200ms连续添加20个节点。
var arr = []; for(var i = 1; i <= 1000; i++){ arr.push(i) } var renderlists = timechunk(arr,function(i){ var div = document.createelement('div'); div.innerhtml = i; document.body.appendchild(div); },20); renderlists(200);
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
下一篇: 大数据应用新的工具 可视化大数据
推荐阅读
-
javascript性能优化之分时函数的介绍
-
javascript的小白教程-之函数的简单介绍与应用方法
-
Sql Server查询性能优化之不可小觑的书签查找介绍
-
javascript性能优化的方法介绍(附示例)
-
javascript性能优化之分时函数的介绍
-
javascript性能优化的方法介绍(附示例)
-
Sql Server查询性能优化之不可小觑的书签查找介绍
-
javascript的小白教程-之函数的简单介绍与应用方法
-
JavaScript性能优化之函数节流(throttle)与函数去抖(debounce)
-
JavaScript性能优化之函数节流(throttle)与函数去抖(debounce)