您好,欢迎来到赴品旅游。
搜索
您的当前位置:首页函数节流与分时函数使用步骤详解

函数节流与分时函数使用步骤详解

来源:赴品旅游

这次给大家带来函数节流与分时函数使用步骤详解,函数节流与分时函数使用的注意事项有哪些,下面就是实战案例,一起来看一下。

分时函数和函数节流的问题不一样,函数节流针对的事件不是用户主动调用的,前面已经提过了。

函数节流的原理是:延迟当前函数的执行,如果该次延迟还没有完成,那么忽略接下来该函数的请求。也就是说会忽略掉很多函数请求。

在一些开发场景中,我们可能会一次性向文档中注入上千个节点,在短时间内向浏览器中大量添加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 p = document.createElement('p');
 p.innerHTML = i;
 document.body.appendChild(p);
},20);
renderLists(200);

相信看了本文案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!

推荐阅读:

Angular服务端渲染方法总结

html字符串转换为HTML标签并使用

Copyright © 2019- fupindai.com 版权所有 赣ICP备2024042792号-2

违法及侵权请联系:TEL:199 1889 7713 E-MAIL:2724546146@qq.com

本站由北京市万商天勤律师事务所王兴未律师提供法律服务