• 技术文章 >web前端 >js教程

    剖析JS分时函数

    php中世界最好的语言php中世界最好的语言2018-05-03 09:46:47原创822
    这次给大家带来剖析JS分时函数,使用JS分时函数的注意事项有哪些,下面就是实战案例,一起来看一下。

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

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

    在一些开发场景中,我们可能会一次性向文档中注入上千个节点,在短时间内向浏览器中大量添加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);

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

    推荐阅读:

    js传递json到controller应该如何操作

    如何让数据里html字段转换为HTML标签

    以上就是剖析JS分时函数的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:javascript 函数 分时
    上一篇:JS里怎样验证E-mail 地址格式 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • 一文探究Angular中的服务端渲染(SSR)• react怎么实现列表排序• 深入浅析Node中的进程和线程• 一文聊聊Node包管理发展的五个阶段• 带你了解Angular组件间进行通信的几种方法
    1/1

    PHP中文网