函数节流和函数防抖

我们知道,js有些事件例如resizemousemove等是会不间断触发的,例如我们简单的一个scroll事件:

function scrollFn() {
    console.log(1)
}
window.onscroll = scrollFn

我们需要在滚动的时候去做一些事情,如上图可见,我们只是简单的console,在一次滚动过程中函数即执行了将近20次,如果这个函数有更为复杂的方法,比如操作dom或者其他交互,会严重影响性能。

为了避免这个问题,我们一般会使用定时器来对函数进行节流。

在javascript高级程序设计中,定义了一个函数节流方法,如下:

function throttle(method,context) { // 执行函数、哪个作用域中执行
    clearTimeout(method.tId);
    method.tId = setTimeout(function() {
        method.call(context)
    },300)
}

throttle函数接收两个参数,即要执行的函数及执行环境,如果执行环境未定义,默认则为windows。在这个函数中,会在第一次执行时为method一个定时器属性,在指定时间间隔(300)内再次执行时会清楚上一次定义的定时器并创建新定时器知道停止。

函数节流

函数预先设定一个执行周期,当调用动作的时刻大于等于执行周期则执行该动作,然后进入下一个新周期。

 function throttle(method, duration) {
    let begin = new Date()
    return function () {
      const context = this, args = arguments
      let current = new Date()
      if (current - begin >= duration) {
        method.apply(context, args)
        begin = current
      }
    }
 }
 function resize() {
    let n = 1
    console.log(++n)
  }

  window.onresize = throttle(resize, 5000)

函数防抖

函数调用n秒后才会执行,如果函数在n秒内被调用的话则函数不执行,重新计算执行时间。

  function debounce(method, delay) {
    let timer = null
    return function () {
      const context = this, args = arguments
      clearTimeout(timer)
      timer = setTimeout(function () {
        method.apply(context, args)
      }, delay)
    }
  }

  function resize() {
    let n = 1
    console.log(++n)
  }

  window.onresize = debounce(resize, 500)

参考文章

函数节流和函数去抖
7分钟理解JS的节流、防抖及使用场景

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 函数节流 还记得上篇文章中说到的图片懒加载吗?我们在文章的最后实现了一个页面滚动时按需加载图片的方式,即在触发滚动...
    柏丘君阅读 2,973评论 1 19
  • 写在前面 在前端开发中,我们知道对于DOM的频繁操作是非常消耗资源的,尤其是对于浏览器的onresize,onsc...
    jeff1804阅读 444评论 0 0
  • 函数防抖和函数节流是在时间轴上控制函数的执行次数 一、函数防抖(debounce)概念:在事件被触发n秒后再执行回...
    puxiaotaoc阅读 453评论 0 1
  • 我们很自豪地宣布一项比赛,获奖者将有权访问 Play2Live 的明斯克开发办公室,预先体验即将推出的测试版平台,...
    Play2Live官方中文社区阅读 353评论 0 0
  • 天气异常炎热,仿佛整条柏油马路快要被晒化了,地上腾起的热浪将等待绿灯的人们包围。我的衬衫湿透了,汗水将它紧紧地贴在...
    之谨阅读 293评论 0 2

友情链接更多精彩内容