节流函数和防抖函数


本文参考于:https://www.jianshu.com/p/1051bfbf8714

项目上线后,经常会报出用户一直点击导致连续出发事件引发体验上的问题,尤其是在监听浏览器滚动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
         }
    }
}

评论
  目录