js的节流与防抖

项目上线后,经常会报出用户一直点击导致连续出发事件引发体验上的问题,尤其是在监听浏览器滚动scroll,页面调整resise的时候,这个时候我们就需要通过节流/防抖来优化这个问题;

防抖:

防抖就是指在某个时间内再次触发事件则会进行重新计时,也就是说一直触发事件则时间在不断重置;举个例子:
function debounce(method, delay){
    var timer = null;
    return function(){
        var context = this,args = arguments;
        clearTimeout(timer);
        timer = setTimeout(function(){
            method.apply(context, args);
        },delay);
    }
}

节流:

所谓节流,就是指在高频触发事件时,只有在大于设定的周期时间内才去触发一次,触发后这个周期时间清零重新开始计算,和防抖的区别就是为了确保在这个周期时间只执行一次;

function throttle(method, delay){
     var last = 0;
     return function (){
        var now = +new Date();
        if(now - last > delay){
            method.apply(this,arguments);
            last = now
         }
    }
}

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 函数节流场景 例如:实现一个原生的拖拽功能(如果不用H5 Drag和Drop API),我们就需要一路监听mous...
    凡凡的小web阅读 817评论 0 0
  • "use strict";function _classCallCheck(e,t){if(!(e instanc...
    久些阅读 2,060评论 0 2
  • Ps: 比如搜索框,用户在输入的时候使用change事件去调用搜索,如果用户每一次输入都去搜索的话,那得消耗多大的...
    燕自浩阅读 5,984评论 0 1
  • 单例模式 适用场景:可能会在场景中使用到对象,但只有一个实例,加载时并不主动创建,需要时才创建 最常见的单例模式,...
    Obeing阅读 2,117评论 1 10
  • 很多人买单反的初衷一定是想要记录生活中的美,希望能用专业的设备拍出更漂亮更美好的画面。可是,当入坑之后会发现,用单...
    圈点摄影阅读 278评论 0 0