前端知識速記:節流與防抖

前端知識速記:節流與防抖

什么是防抖?

防抖是一種控制事件觸發頻率的方法,通常用于處理用戶頻繁觸發事件的場景。防抖的核心思想是將多個連續觸發事件合并為一個事件,以減少執行次數。它在以下場景中特別有效:

  • 輸入框輸入事件:實時搜索、輸入驗證等。
  • 窗口調整大小(resize)事件:減少窗口大小變化時的處理頻率。

防抖的實現

防抖的實現依賴于計時器。每次觸發事件時,都會重置計時器,只有在事件停止觸發一定時間后才執行該事件處理函數。

function debounce(fn, delay) {let timer = null;return function(...args) {if (timer) clearTimeout(timer);timer = setTimeout(() => {fn.apply(this, args);}, delay);};
}// 使用示例
const input = document.getElementById('input');
input.addEventListener('input', debounce(() => {console.log('用戶輸入:', input.value);
}, 300));

在這個例子中,輸入事件會在用戶停止輸入后 300 毫秒觸發,避免了頻繁的輸出。

什么是節流?

節流與防抖的目標相似,但其實現方式有所不同。節流是指限制事件的觸發頻率,保證在一定時間內事件只會執行一次。節流特別適合以下場景:

  • 滾動監聽:限制滾動事件的處理,避免性能瓶頸。
  • 定時器定時執行任務:實現定期執行的功能。

節流的實現

節流可以通過時間戳或定時器實現。這里展示使用時間戳進行節流的示例:

function throttle(fn, limit) {let lastTime = 0;return function(...args) {const now = Date.now();if (now - lastTime >= limit) {lastTime = now;fn.apply(this, args);}};
}// 使用示例
window.addEventListener('scroll', throttle(() => {console.log('用戶在滾動');
}, 500));

在這個例子中,用戶滾動事件的處理函數每 500 毫秒最多觸發一次,以減少計算量和提高性能。

節流與防抖的區別

  • 觸發時機:防抖在事件觸發后的一段時間內若再次觸發則會重新計時,保證事件只執行一次;而節流是保證在一定時間內只執行一次,無論事件觸發了多少次。
  • 適用場景:防抖適用于用戶輸入等需要等待用戶停止操作的場景;節流適用于需要在一定時間內持續操作的場景,例如滾動或窗口縮放。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/67665.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/67665.shtml
英文地址,請注明出處:http://en.pswp.cn/web/67665.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

無人機圖傳模塊 wfb-ng openipc-fpv,4G

openipc 的定位是為各種模塊提供底層的驅動和linux最小系統,openipc 是采用buildroot系統編譯而成,因此二次開發能力有點麻煩。為啥openipc 會用于無人機圖傳呢?因為openipc可以將現有的網絡攝像頭ip-camera模塊直接利用起來,從而…

藍橋杯例題一

不管遇到多大的困難,我們都要堅持下去。每一次挫折都是我們成長的機會,每一次失敗都是我們前進的動力。路漫漫其修遠兮,吾將上下而求索。只有不斷努力奮斗,才能追逐到自己的夢想。不要害怕失敗,害怕的是不敢去嘗試。只…

【JavaEE進階】圖書管理系統 - 壹

目錄 🌲序言 🌴前端代碼的引入 🎋約定前后端交互接口 🚩接口定義 🍃后端服務器代碼實現 🚩登錄接口 🚩圖書列表接口 🎄前端代碼實現 🚩登錄頁面 🚩…

【算法設計與分析】實驗8:分支限界—TSP問題

目錄 一、實驗目的 二、實驗環境 三、實驗內容 四、核心代碼 五、記錄與處理 六、思考與總結 七、完整報告和成果文件提取鏈接 一、實驗目的 掌握分支界限求解問題的思想;針對不同的問題,能夠利用分支界限法進行問題拆分和求解以及時間復雜度分析…

【3】阿里面試題整理

[1]. ES架構,如何進行路由以及選主 路由:在Elasticsearch(ES)中,默認的路由算法是基于文檔的_id。具體來說,Elasticsearch會對文檔的_id進行哈希計算,然后對分片數量取模,以確定該文…

【Linux】opencv在arm64上提示找不到libjasper-dev

解決opencv在arm64上提示找不到libjasper-dev的問題。 本文首發于?慕雪的寒舍 問題說明 最近我在嘗試編譯opencv,安裝依賴項libjasper1和libjasper-dev的時候就遇到了這個問題。在amd64平臺上,我們可以通過下面的命令安裝(ubuntu18.04&…

【數據結構】_時間復雜度相關OJ(力扣版)

目錄 1. 示例1:消失的數字 思路1:等差求和 思路2:異或運算 思路3:排序+二分查找 2. 示例2:輪轉數組 思路1:逐次輪轉 思路2:三段逆置(經典解法) 思路3…

基于微信小程序的電子商城購物系統設計與實現(LW+源碼+講解)

專注于大學生項目實戰開發,講解,畢業答疑輔導,歡迎高校老師/同行前輩交流合作?。 技術范圍:SpringBoot、Vue、SSM、HLMT、小程序、Jsp、PHP、Nodejs、Python、爬蟲、數據可視化、安卓app、大數據、物聯網、機器學習等設計與開發。 主要內容:…

【linux】Linux 常見目錄特性、權限和功能

目錄特性默認權限主要功能/用途/根目錄,所有目錄的起點755文件系統的頂層目錄,包含所有其他子目錄和文件/bin基礎二進制命令目錄(系統啟動和修復必需的命令)755存放所有用戶可用的基本命令(如 ls, cp, bash 等&#xf…

docker直接運行arm下的docker

運行環境是樹莓派A 處理器是 arm32v6 安裝了docker,運行lamp 編譯安裝php的時候發現要按天來算,于是用電腦vm下的Ubuntu系統運行arm的docker 然后打包到a直接導入運行就可以了 第一種方法 sudo apt install qemu-user-static 導入直接運行就可以了…

計算機網絡一點事(22)

地址解析協議ARP ARP:查詢Mac地址 ARP表(ARP緩存):記錄映射關系,一個數據結構,定期更新ARP表 過程:請求分組,響應分組 動態主機配置協議DHCP 分配IP地址,配置默認網關…

tomcat核心組件及原理概述

目錄 1. tomcat概述 1.1 概念 1.2 官網地址 2. 基本使用 2.1下載 3. 整體架構 3.1 核心組件 3.2 從web.xml配置和模塊對應角度 3.3 如何處理請求 4. 配置JVM參數 5. 附錄 1. tomcat概述 1.1 概念 什么是tomcat Tomcat是一個開源、免費、輕量級的Web服務器。 Tomca…

科技快訊 | OpenAI首次向免費用戶開放推理模型;特朗普與黃仁勛會面;雷軍回應“10后小學生深情表白小米SU7”

不用開口:谷歌 AI 幫你致電商家,價格、預約一鍵搞定 谷歌在1月30日推出Search Labs中的“Ask for Me”實驗性功能,用戶可利用AI代替自己致電商家咨詢價格和服務。該功能已與美汽車修理廠和美甲沙龍店合作,用戶需加入Search Labs并…

帆軟 FCA -業務分析師認證學習

帆軟 FCA -業務分析師認證學習 認證概述 適合人群 企業中有需求管理、指標梳理、業務邏輯梳理、項目規劃等需求的人員,想提升綜合數據能力、推進數據應用落地的業務/IT骨干。 具體-FCA-業務分析理論 考試要求: FCA-業務分析理論考試- 費用&#xff1a…

Vue.js路由管理與自定義指令深度剖析

Vue.js 是一個強大的前端框架,提供了豐富的功能來幫助開發者構建復雜的單頁應用(SPA)。本文將詳細介紹 Vue.js 中的自定義指令和路由管理及導航守衛。通過這些功能,你可以更好地控制視圖行為和應用導航,從而提升用戶體驗和開發效率。 1 自定義指令詳解 1.1 什么是自定義…

Maya軟件安裝步驟與百度網盤鏈接

軟件簡介: MAYA軟件是Autodesk旗下的著名三維建模和動畫軟件。maya軟件功能更為強大,體系更為完善,因此國內很多的三維動畫制作人員都開始轉向maya,maya軟件已成為三維動畫軟件的主流。 百度網盤鏈接: https://pan.baidu.com/s…

kamailio的部分模塊的解釋及代碼示例【文章由DeekSeek大模型提供】

以下是 Kamailio 中這些模塊的詳細說明及示例代碼: 1. tls.so 作用:提供 TLS 支持,用于加密 SIP 通信。示例:loadmodule "tls.so" modparam("tls", "certificate", "/etc/kamailio/tls/serve…

深入理解linux中的文件(上)

1.前置知識: (1)文章 內容 屬性 (2)訪問文件之前,都必須打開它(打開文件,等價于把文件加載到內存中) 如果不打開文件,文件就在磁盤中 (3&…

一個用于測試的 HL7 Server

說明 一個用于測試的 HL7 Server。在過NIST的認證時,需要演示檢驗數據通過HL7進行傳輸,所以寫了這工具。 HL7的消息解析和編碼使用了NHapi。包含兩個服務: ReceiveServiceSendService 這2個服務都繼承自 BaseService public class BaseSe…

使用 Go 和 gqlgen 實現 GraphQL API:實戰指南

使用 Go 和 gqlgen 實現 GraphQL API:實戰指南 在本文中,我將分享如何使用 Go 語言和 gqlgen 框架實現一個完整的 GraphQL API。我們將構建一個包含用戶、文章和評論功能的博客系統 API。 技術棧 Gogqlgen (GraphQL 框架)MySQL (數據存儲)Redis (緩存…