欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

javascript之分时函数

程序员文章站 2022-04-04 21:22:13
timeChunk函数让创建节点的工作分批进行,比如一秒钟创建1000个节点,改为每个200ms创建10个节点。具体timeChunk函数封装如下 应用实例见https://92node.com/article/js-fen-shi.html ......
在一些开发场景中,我们可能会一次性向文档中注入上千个节点,在短时间内向浏览器中大量添加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)
    }
}

应用实例见https://92node.com/article/js-fen-shi.html