手写一个防抖

简介: 手写一个防抖

防抖是一种前端开发中常用的性能优化技术,特别是在处理用户输入或其他频繁触发的事件时。防抖的目的是通过延迟执行来合并连续的触发,以减少频繁操作对系统性能的影响。

手写防抖函数

function debounce(func, delay) {
   
  let timerId;

  return function (...args) {
   
    if (timerId) {
   
      clearTimeout(timerId);
    }

    timerId = setTimeout(() => {
   
      func.apply(this, args);
    }, delay);
  };
}

// 示例用法
const debouncedFunction = debounce(() => {
   
  console.log("防抖触发了!");
}, 300);

// 在事件处理中使用
document.getElementById("myInput").addEventListener("input", debouncedFunction);

防抖的原理

防抖的原理很简单:当事件被触发时,不立即执行处理函数,而是设置一个定时器,在指定的延迟时间后再执行。如果在这个延迟时间内事件再次触发,就清除之前的定时器,重新设置一个新的定时器。这样,只有在事件停止触发一段时间后,处理函数才会被执行。

为什么需要防抖?

  1. 性能优化: 频繁触发的事件,如输入框输入、窗口大小变化等,可能导致大量的计算和DOM操作。通过防抖,可以减少不必要的操作,提高性能。

  2. 减少请求: 在处理输入框输入时,如果每次输入都发送请求,可能会导致不必要的网络请求。通过防抖,可以确保用户停止输入一段时间后再发送请求,减轻服务器负担。

  3. 避免重复操作: 防抖还可以防止重复操作,特别是一些需要用户交互的操作,如点击按钮触发的事件。

如何使用防抖?

  1. 导入防抖函数: 将防抖函数引入你的项目中。

  2. 创建防抖实例: 使用防抖函数创建一个防抖实例,传入需要防抖的处理函数和延迟时间。

  3. 事件绑定: 在需要应用防抖的地方,将防抖实例作为事件处理函数绑定。

const debouncedFunction = debounce(() => {
   
  console.log("防抖触发了!");
}, 300);

document.getElementById("myInput").addEventListener("input", debouncedFunction);

通过上述步骤,你就成功地在项目中应用了防抖技术,优化了性能并提升了用户体验。在实际项目中,可以根据需要调整延迟时间,以平衡性能和响应速度。

目录
相关文章
|
8月前
15 # 手写 throttle 节流方法
15 # 手写 throttle 节流方法
54 0
|
5月前
|
存储 前端开发 JavaScript
面试时让你手写一个防抖和节流优化,你能写出来吗?(二)
面试时让你手写一个防抖和节流优化,你能写出来吗?(二)
|
5月前
|
前端开发 UED
面试时让你手写一个防抖和节流优化,你能写出来吗?(一)
面试时让你手写一个防抖和节流优化,你能写出来吗?(一)
|
6月前
|
缓存 开发框架 前端开发
前端性能优化【前端必备】(含懒加载,手写防抖、节流等)
前端性能优化【前端必备】(含懒加载,手写防抖、节流等)
87 4
|
前端开发
手写防抖
手写防抖
70 0
|
8月前
|
前端开发 JavaScript 程序员
【面试题】 js-面试官要求手写节流防抖?
【面试题】 js-面试官要求手写节流防抖?
|
8月前
14 # 手写 debounce 防抖方法
14 # 手写 debounce 防抖方法
59 1
|
前端开发
手写防抖节流
手写防抖节流
105 0
|
JavaScript 前端开发 Java
手写JavaScript防抖节流和休眠函数
防抖原理是在一定时间内,只有最后一次操作,再过延迟的时间后执行,一般用于防止用户多次重复点击按钮,只会触发最后一次
62 0
|
监控 前端开发
前端经典面试题 | 理解 节流 和 防抖(后附手写节流\防抖)
前端经典面试题 | 理解 节流 和 防抖(后附手写节流\防抖)