什么是防抖和节流?如何实现防抖和节流?

27. 什么是防抖和节流?如何实现防抖和节流?

防抖(debounce)和节流(throttle)是 JavaScript 中常用的两种性能优化方法。

1. 防抖

防抖指的是在事件被触发 n 秒后再执行回调函数,如果在这 n 秒内又触发了该事件,则会重新计时,直到 n 秒后才执行回调函数。防抖通常用于需要在连续事件触发的情况下只执行一次回调函数的场景,比如搜索框输入联想等。

一个简单的防抖实现:

function debounce(fn, wait) {
  let timer = null
  return function() {
    if(timer)clearTimeout(timer)
    timer = setTimeout(() => {
      fn.apply(this, arguments)
    }, wait);
  }
}

2. 节流

节流指的是每隔一段时间就执行一次回调函数,即每隔 n 秒执行一次回调函数。节流通常用于需要控制事件触发频率的场景,比如滚动事件、窗口大小变化等。

一个简单的节流实现:

// 节流 定时器版
function throttle(fn, wait) {
  let timer = null
  return function() {
    if(!timer) {
      timer = setTimeout(() => {
        timer = null
        fn.apply(this, arguments)
      }, wait)
    }
  }
}

// 节流 时间戳版
function throttle1(fn, wait) {
  let prev = 0
  return function() {
    let now = Date.now()
    if(now - prev >= wait) {
      fn.apply(this, arguments)
      prev = now
    }
  }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容