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

使用lodash库实现防抖和节流

在 JavaScript 中,lodash 是一个非常流行的实用工具库,提供了许多常用的函数,其中就包括防抖节流的实现。lodash 提供的 debouncethrottle 函数可以让我们更方便地实现这两种功能。

1. 使用 lodashdebounce(防抖)函数

lodashdebounce 函数可以帮助我们在用户停止操作一段时间后才触发事件。它的使用方式非常简洁。

示例:搜索框输入防抖

在这个示例中,我们希望用户在输入框中停止输入 500 毫秒后才执行搜索操作,避免频繁请求。

<input type="text" id="search" placeholder="Search...">

<script src="https://cdn.jsdelivr.net/npm/lodash@4.17.21/lodash.min.js"></script>
<script>
    // 假设这是一个执行搜索操作的函数
    function performSearch(query) {
        console.log('Searching for:', query);
        // 这里可以发送 ajax 请求进行搜索
    }

    // 使用 lodash 的 debounce 函数
    const debouncedSearch = _.debounce(function(event) {
        performSearch(event.target.value);
    }, 500);  // 500ms 的防抖时间

    // 监听输入框的输入事件
    document.getElementById('search').addEventListener('input', debouncedSearch);
</script>
  • 解释
    • 当用户输入时,debouncedSearch 函数会被连续调用,但只有当用户停止输入超过 500 毫秒时,performSearch 函数才会执行一次。
    • 防止在每次键盘输入时都发起请求,优化了性能。

2. 使用 lodashthrottle(节流)函数

lodashthrottle 函数允许我们在规定的时间间隔内最多执行一次事件处理函数,即使在这段时间内事件被多次触发。

示例:滚动事件节流

在这个示例中,我们希望当用户滚动页面时,每隔 1 秒才记录一次滚动事件,避免频繁触发回调函数。

<div style="height: 2000px;">Scroll down to see the effect</div>

<script src="https://cdn.jsdelivr.net/npm/lodash@4.17.21/lodash.min.js"></script>
<script>
    // 这是一个处理滚动事件的函数
    function handleScroll() {
        console.log('Scroll event detected at:', new Date().toLocaleTimeString());
    }

    // 使用 lodash 的 throttle 函数,每隔 1 秒最多触发一次
    const throttledScroll = _.throttle(handleScroll, 1000);

    // 监听滚动事件
    window.addEventListener('scroll', throttledScroll);
</script>
  • 解释
    • 当用户滚动页面时,throttledScroll 函数会在 1 秒内最多触发一次,避免滚动时回调函数被频繁调用。
    • 这优化了页面滚动的性能,特别是在回调函数较为复杂时。

3. 防抖和节流的高级用法

lodashdebouncethrottle 函数还支持一些高级选项,可以灵活控制事件的执行时机。例如:

  • leading:是否在开始时立即执行函数。
  • trailing:是否在停止触发后再执行函数。
示例:结合 leadingtrailing 选项

假设我们希望在用户第一次触发事件时立即执行函数,并在停止触发 1 秒后再次执行。

<input type="text" id="input-field" placeholder="Type something...">

<script src="https://cdn.jsdelivr.net/npm/lodash@4.17.21/lodash.min.js"></script>
<script>
    // 假设这是一个处理输入的函数
    function handleInput(value) {
        console.log('Input value processed:', value);
    }

    // 使用 debounce 函数,并配置 leading 和 trailing 选项
    const debouncedInput = _.debounce(function(event) {
        handleInput(event.target.value);
    }, 1000, { leading: true, trailing: true });

    // 监听输入框的输入事件
    document.getElementById('input-field').addEventListener('input', debouncedInput);
</script>
  • 解释
    • leading: true:用户开始输入时,立即执行 handleInput 函数。
    • trailing: true:用户停止输入 1 秒后,再次执行 handleInput 函数。
    • 这样我们既可以在输入时立即响应,又可以在用户停止输入后执行最后一次处理。

4. 总结

  • 防抖(Debounce)

    • 在短时间内频繁触发时,只有最后一次操作才执行。
    • 适合场景:输入框搜索、窗口大小调整等。
  • 节流(Throttle)

    • 在一定时间间隔内保证事件只触发一次,无论事件多频繁。
    • 适合场景:页面滚动、按钮点击、鼠标移动等。

使用 lodashdebouncethrottle 函数,不仅简化了代码,还提高了应用性能和可维护性。


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

相关文章:

  • Redis在高性能缓存中的应用
  • git撤销、回退某个commit的修改
  • 「Mac玩转仓颉内测版5」入门篇5 - Cangjie控制结构(上)
  • Spring Boot 启动时自动配置 RabbitMQ 交换机、队列和绑定关系
  • 软考教材重点内容 信息安全工程师 第 4 章 网络安全体系与网络安全模型
  • shell编程之变量与引用
  • Easy Excel从入门到精通!!!
  • pg入门11-pg中的publications是什么
  • SpringBoot整合Lombok插件与使用说明
  • 微信小程序showLoading ,showToast ,hideLoading连续调用出现showLoading 不关闭的情况记录
  • SpringDoc OpenApi学习笔记
  • GO Ants 学习
  • C++——将数组a[5]={-1,2,9,-5,7}中小于0的元素置成0。并将其结果输出(要求:用数组名作为函数的参数来实现)
  • C++游戏
  • Linux部署python web项目Flask + gunicorn + nginx
  • 《经典图论算法》约翰逊算法(Johnson)
  • 前端插件开发用什么技术比较好,用来程序自动化下载
  • TypeScript 设计模式之【单例模式】
  • [每日一练]修复表中的名字
  • Dependency Check:一款针对应用程序依赖组件的安全检测工具
  • ACM MM24 | Hi3D: 3D生成领域再突破!新视角生成和高分辨率生成双SOTA(复旦智象等)
  • Java 编码系列:异常处理与自定义异常
  • 一些广泛认可的编程工具,在不同的方面帮助我们提升效率
  • 使用cmd命令窗口操作mongodb
  • Scikit-LearnTensorFlow机器学习实用指南(三):一个完整的机器学习项目【下】
  • mask2former训练自定义数据集