当前位置: 首页 > article >正文

js的节流和防抖详解

防抖和节流是JavaScript中的常见优化技巧,它们可以帮助我们控制代码在特定的时间间隔内执行的频率,从而优化性能。下面详细讲解它们的原理和使用方法。

防抖(Debounce):

防抖的原理是当一个事件频繁触发时,只有在停止触发一段时间后,才会执行相应的代码。比如用户在输入框中连续输入,我们不必要每次都去响应用户的输入,而是在用户停止输入一段时间后再去响应。

防抖的实现方法很简单,通过设置一个定时器,来延迟执行函数。如果在定时器执行之前,又触发了该事件,就取消定时器,并重新设置一个新的定时器。

使用示例:

function debounce(func, delay) {
  let timer;
  return function() {
    clearTimeout(timer);
    timer = setTimeout(() => {
      func.apply(this, arguments);
    }, delay);
  }
}

const debouncedFunc = debounce(() => {console.log('执行');}, 1000);
debouncedFunc();
debouncedFunc();
debouncedFunc(); //只会输出一次“执行”

节流(Throttle):

节流的原理是当一个事件频繁触发时,只会在特定的时间间隔内执行一次相应的代码。比如在滚动页面的时候,我们不必要每次都去响应滚动事件,而是在特定的时间间隔内去响应。

节流的实现方法也很简单,在每次执行代码之前,先判断当前时间间隔是否达到了预设的时间间隔,如果达到了,就执行相应的代码,并重新设置计时器;如果没达到,就忽略这次触发。

使用示例:

function throttle(func, delay) {
  let timer;
  let lastTime = 0;
  return function() {
    const currentTime = new Date().getTime();
    if (currentTime - lastTime >= delay) {
      lastTime = currentTime;
      func.apply(this, arguments);
    } else {
      clearTimeout(timer);
      timer = setTimeout(() => {
        lastTime = currentTime;
        func.apply(this, arguments);
      }, delay - (currentTime - lastTime));
    }
  }
}

const throttledFunc = throttle(() => {console.log('执行');}, 1000);
throttledFunc();
throttledFunc();
throttledFunc(); //只会输出两次“执行”

总结:

防抖和节流都是常见的优化技巧,它们能控制代码的执行频率,优化性能,提高用户体验。需要根据具体的场景选择使用哪一种技巧。


http://www.kler.cn/a/103787.html

相关文章:

  • 微信小程序连接数据库与WXS的使用
  • T113-S3-buildroot文件系统tar解压缩gz文件
  • 单窗口单IP适合炉石传说游戏么?
  • 【单链表,循环链表和双向链表的时间效率比较,顺序表和链表的比较,有序表的合并------用顺序表实现,用链表实现】
  • 【ArcGIS模型构建器】05:批量为多个矢量数据添加相同的字段
  • 【Java】泛型通配符
  • 回归预测 | MATLAB实现BO-LSTM贝叶斯优化长短期神经网络多输入单输出回归预测
  • 路由器和交换机之间的区别
  • Docker部署
  • 面试常问的C++算法(有题目和答案)
  • 大数据技术学习笔记(三)—— Hadoop 的运行模式
  • springboot188基于spring boot的校园商铺管理系统
  • uview组件使用笔记
  • 力扣每日一题64:最小路径和
  • 国内智能客服机器人都有哪些?
  • 集合总结-
  • vue部署,chunk文件有部分404,解决方案
  • 【Java面试题汇总】ElasticSearch篇(2023版)
  • STM32F103单片机内部RTC实时时钟驱动程序
  • 神经网络中epoch、batch、batchsize区别