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

JS 防抖和节流

防抖(debounce)和节流(throttle)是JavaScript中常用的性能优化技术,用于限制某些高频率触发的函数执行次数,减少不必要的计算和网络请求。下面分别介绍防抖和节流的实现方式。

防抖(Debounce)

防抖的原理是在事件触发后等待一段时间,如果在这段时间内没有再次触发该事件,就执行函数;如果再次触发了该事件,则重新计时。这样可以确保只有事件停止触发后才会执行函数。

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

使用示例:

// 定义一个需要防抖处理的函数
function search() {// 执行搜索操作
}// 创建防抖函数
const debouncedSearch = debounce(search, 300);// 添加事件监听器
const searchInput = document.getElementById("search-input");
searchInput.addEventListener("input", debouncedSearch);

当用户输入搜索关键字时,会触发input事件并调用debouncedSearch函数。但由于应用了防抖,只有在停止输入300毫秒后才会实际执行搜索操作。

节流(Throttle)

节流的原理是规定一个时间间隔,在这个时间间隔内,只能执行一次函数。如果在该时间间隔内多次触发该函数,只有第一次会被执行,后续的触发将被忽略。

function throttle(func, interval) {let lastTime = 0;return function() {const currentTime = Date.now();if (currentTime - lastTime > interval) {func.apply(this, arguments);lastTime = currentTime;}};
}

 使用示例:

// 定义一个需要节流处理的函数
function scrollHandler() {// 处理滚动事件
}// 创建节流函数
const throttledScroll = throttle(scrollHandler, 200);// 添加事件监听器
window.addEventListener("scroll", throttledScroll);

 当用户滚动页面时,会触发scroll事件并调用throttledScroll函数。由于应用了节流,每200毫秒才会实际处理一次滚动事件,减少了函数的触发次数。

http://www.lryc.cn/news/214565.html

相关文章:

  • Django开发实例总结(入门级、4.2.6、详细)
  • Variations-of-SFANet-for-Crowd-Counting可视化代码
  • 所有的人机交互都存在不匹配现象
  • LED数码管的静态显示与动态显示(Keil+Proteus)
  • webGL编程指南 第五章 TexturedQuad_Clamp_Mirror
  • 【Azure】存储服务:Azure 的存储账户
  • 高等数学啃书汇总重难点(十一)曲线积分与曲面积分
  • 【算法专题】双指针—盛最多水的容器
  • java入门,程序=数据结构+算法
  • 9.MySQL索引的操作
  • 大型加油站3d全景虚拟现实展示平台实现全方位立体呈现
  • Reading:Deep dive into the OnPush change detection strategy in Angular
  • 野火霸天虎 STM32F407 学习笔记_1 stm32介绍;调试方法介绍
  • @reduxjs/toolkit配置react-redux解决createStore或将在未来被淘汰警告
  • 致敬1024天前的自己
  • 〖Python网络爬虫实战㊱〗- JavaScript 网站加密和混淆
  • 基于单片机设计的电子柜锁
  • Windows安装tensorflow-gpu=1.14.0CUDA=10.0cuDNN=7.4 (多版本CUDA共存)
  • CodeWhisperer 初体验
  • HNU-算法设计与分析-讨论课1
  • java连接zookeeper
  • 2023-11-01 node.js-electron-环境配置-记录
  • 使用 ElementUI 组件构建 Window 桌面应用探索与实践(WinForm)
  • 使用C++构建安全队列
  • EasyFlash移植使用- 关于单片机 BootLoader和APP均使用的情况
  • python捕获异常和scapy模块的利用
  • CSS+Javascript+Html日历控件
  • 让企业的数据用起来,数据中台=数据治理?
  • 【人工智能Ⅰ】5-粒子群算法
  • 软考高项-49个项目管理过程输入、输出和工具技术表