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

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

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
    }
  }
}
相关文章
|
1月前
节流、防抖
节流、防抖
20 2
|
1月前
|
前端开发 UED
关于防抖和节流的理解
防抖和节流是前端开发中常用的两种性能优化技术。
12 0
|
10月前
什么是防抖和节流,怎么实现一个防抖和节流?
功能:当事件被触发N秒之后再执行回调,如果在N秒内被触发,则重新计时。
面试官:防抖和节流的区别是啥?实现一个防抖和节流函数(二)
面试官:防抖和节流的区别是啥?实现一个防抖和节流函数(二)
|
10月前
|
前端开发 UED
面试官:防抖和节流的区别是啥?实现一个防抖和节流函数(一)
面试官:防抖和节流的区别是啥?实现一个防抖和节流函数(一)
|
10月前
|
JavaScript 前端开发
节流与防抖
节流与防抖
31 0
|
10月前
|
前端开发
什么是防抖和节流?有什么区别?
什么是防抖和节流?有什么区别?
54 0
防抖&节流
防抖&节流
95 0