谈谈前端开发中的防抖和节流

本文作者为 360 奇舞团前端开发工程师 李武阳

概述

防抖节流是前端开发中常用的函数优化手段,它们可以限制函数的执行频率,提升性能和用户体验。主要用于处理高频触发的事件,例如:用户的滚动、输入、点击和表单的重复提交等。

防抖与节流的区别

先简单描述下它们的作用

防抖:如果一个函数持续地、频繁地触发,那么只在它结束后过一段时间才开始执行。换句话说,如果你持续触发事件,那么防抖函数将不会执行,只有当你停止触发事件后,它才会在指定的延迟时间后执行。这对于防止例如用户在输入框中连续输入时发送过多的Ajax请求等情况非常有用。

节流:如果你持续触发事件,每隔一段时间,事件处理函数只执行一次。这有助于限制一些处理函数的执行频率,例如:滚动事件、窗口大小调整事件等。

简而言之,防抖是在事件停止触发后延迟执行函数,而节流是按照固定的时间间隔执行函数。

因为防抖节流的作用和应用场景基本相同,也就导致它们容易被混淆。

防抖的实现与使用

防抖的应用场景:

  1. 输入框搜索:当用户在搜索框中输入关键字时,使用防抖可以避免频繁发送搜索请求,而是在用户停止输入一段时间后才发送请求,减轻服务器压力。
  2. 按钮点击:当用户点击按钮时,使用防抖可以避免用户多次点击造成的多次提交或重复操作。

实现防抖的基本方式是利用定时器,每次触发事件时都清除上一次的定时器,然后重新设置一个新的定时器。

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <button id="btn">按钮</button>
    <script>
       
        // 防抖函数  
        function debounce(func, wait) {  
            let timeout;  
            return function (...args) {  
                const context = this;  
                clearTimeout(timeout);  
                timeout = setTimeout(() => func.apply(context, args), wait);  
            };  
        }  

        // 使用防抖函数控制连续触发事件的处理函数执行频率  
        const debouncedHandler = debounce(() => {  
            console.log('Debounced event triggered');  
        }, 500);  

        document.getElementById('btn').addEventListener('click',debouncedHandler)
    </script>
</body>

</html>

节流的实现与使用

节流的应用场景:

  1. 页面滚动:当页面滚动时,使用节流可以限制滚动事件的触发频率,减少事件处理的次数,提高页面的响应性能。
  2. 按钮点击:当用户点击按钮时,使用节流可以减少事件处理的次数,避免过于频繁的操作。

实现节流的方式也是利用定时器,但与防抖不同的是,节流会保证在一个固定的时间间隔内至少执行一次事件处理函数。

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <button id="btn">按钮</button>
    <script>
       
       // 节流函数  
        function throttle(func, limit) {  
            let inThrottle;  
            return function (...args) {  
                const context = this;  
                if (!inThrottle) {  
                func.apply(context, args);  
                inThrottle = true;  
                setTimeout(() => inThrottle = false, limit);  
                }  
            };  
        }

        // 使用节流函数控制连续触发事件的处理函数执行频率  
        const throttledHandler = throttle(() => {  
            console.log('Throttled event triggered');  
        }, 1000);

        document.getElementById('btn').addEventListener('click',throttledHandler)
    </script>
</body>

</html>

总结

在实际的前端开发中,防抖和节流的使用场景非常广泛。例如:搜索框的实时搜索建议可以使用防抖来减少服务器请求;滚动加载更多数据可以使用节流来防止在短时间内发送过多的请求。通过使用这两种技术,我们可以有效地优化前端的性能,提升用户体验。

相关推荐
gCode Teacher 格码致知13 小时前
Javascript提高:get和post等请求,对于汉字和空格信息进行编码的原则-由Deepseek产生
开发语言·前端·javascript·node.js·jquery
竹林81813 小时前
从ethers.js迁移到Viem:我在一个DeFi项目前端重构中踩过的坑
前端·javascript
像我这样帅的人丶你还14 小时前
从交稿到甩锅预防:AI 前端流水线
前端·ai编程
想想弹幕会怎么做14 小时前
如何构建一颗可交互的ui树?
前端
程序员陆业聪14 小时前
我见过的最反直觉的 Android 架构问题:UseCase 越多,项目越烂
前端
Arya_aa14 小时前
网络:前端向后端发送网络请求渲染在页面上,将EasyMock中的信息用前端vue框架编写代码,最终展示在浏览器
前端·vue.js
LlNingyu14 小时前
文艺复兴,什么是CSRF,常见形式(一)
前端·安全·web安全·csrf
晓131314 小时前
React篇——第三章 状态管理之 Redux 篇
前端·javascript·react.js
子兮曰14 小时前
🚀24k Star 的 Pretext 为何突然爆火:它不是排版库,而是在重写 Web 文本测量
前端·javascript·github
@大迁世界14 小时前
11.在 React.js 中,state 与 props 的差异体现在哪里?
前端·javascript·react.js·前端框架·ecmascript