深入了解JavaScript 防抖和節(jié)流
概述
說明
在項(xiàng)目過程中,經(jīng)常會(huì)遇到一個(gè)按鈕被多次點(diǎn)擊并且多次調(diào)用對(duì)應(yīng)處理函數(shù)的問題,而往往我們只需去調(diào)用一次處理函數(shù)即可。有時(shí)也會(huì)遇到需要在某一規(guī)則內(nèi)有規(guī)律的去觸發(fā)對(duì)應(yīng)的處理函數(shù),所以就需要使用到函數(shù)防抖與函數(shù)節(jié)流來幫助我們實(shí)現(xiàn)我們想要的結(jié)果以及避免不必要的問題產(chǎn)生。
函數(shù)防抖(debounce)
定義:當(dāng)持續(xù)觸發(fā)事件時(shí)(如連續(xù)點(diǎn)擊按鈕多此),一定時(shí)間段內(nèi)沒有再觸發(fā)事件,事件處理函數(shù)才會(huì)執(zhí)行一次,如果設(shè)定的時(shí)間到來之前,有一次觸發(fā)了事件,就重新開始延時(shí)。
原理:維護(hù)一個(gè)計(jì)時(shí)器,規(guī)定在延時(shí)時(shí)間后觸發(fā)函數(shù),但是在延時(shí)時(shí)間內(nèi)再次被觸發(fā)的話,就取消之前的計(jì)時(shí)器而重新設(shè)置,這樣就能夠保證只有最后一次操作被觸發(fā)。即將所有操作合并為一個(gè)操作進(jìn)行,并且只有最后一次操作是有效操作。
函數(shù)節(jié)流(throttle)
定義:當(dāng)持續(xù)觸發(fā)事件時(shí),保證一定時(shí)間段內(nèi)只調(diào)用一次事件處理函數(shù),按照一定的規(guī)律在某個(gè)時(shí)間間隔內(nèi)去處理函數(shù)。
原理:原理是通過判斷是否達(dá)到一定時(shí)間來觸發(fā)函數(shù),使得一定時(shí)間內(nèi)只觸發(fā)一次函數(shù)。
代碼
函數(shù)防抖
觸發(fā)高頻事件后n秒內(nèi)函數(shù)只會(huì)執(zhí)行一次,如果n秒內(nèi)高頻事件再次被觸發(fā),則重新計(jì)算時(shí)間
每次觸發(fā)事件時(shí)都取消之前的延時(shí)調(diào)用方法
function debounce(fn) { let timeout = null; // 創(chuàng)建一個(gè)標(biāo)記用來存放定時(shí)器的返回值 return function () { clearTimeout(timeout); // 每當(dāng)用戶輸入的時(shí)候把前一個(gè) setTimeout clear 掉 timeout = setTimeout(() => { // 然后又創(chuàng)建一個(gè)新的 setTimeout, 這樣就能保證輸入字符后的 interval 間隔內(nèi)如果還有字符輸入的話,就不會(huì)執(zhí)行 fn 函數(shù) fn.apply(this, arguments); }, 500); }; } function sayHi() { console.log('防抖成功'); } var inp = document.getElementById('inp'); inp.addEventListener('input', debounce(sayHi)); // 防抖
函數(shù)節(jié)流
高頻事件觸發(fā),但在n秒內(nèi)只會(huì)執(zhí)行一次,所以節(jié)流會(huì)稀釋函數(shù)的執(zhí)行頻率
每次觸發(fā)事件時(shí)都判斷當(dāng)前是否有等待執(zhí)行的延時(shí)函數(shù)
function throttle(fn) { let canRun = true; // 通過閉包保存一個(gè)標(biāo)記 return function () { if (!canRun) return; // 在函數(shù)開頭判斷標(biāo)記是否為true,不為true則return canRun = false; // 立即設(shè)置為false setTimeout(() => { // 將外部傳入的函數(shù)的執(zhí)行放在setTimeout中 fn.apply(this, arguments); // 最后在setTimeout執(zhí)行完畢后再把標(biāo)記設(shè)置為true(關(guān)鍵)表示可以執(zhí)行下一次循環(huán)了。當(dāng)定時(shí)器沒有執(zhí)行的時(shí)候標(biāo)記永遠(yuǎn)是false,在開頭被return掉 canRun = true; }, 500); }; } function sayHi(e) { console.log(e.target.innerWidth, e.target.innerHeight); } window.addEventListener('resize', throttle(sayHi));
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 如何在面試中手寫出javascript節(jié)流和防抖函數(shù)
- js節(jié)流防抖應(yīng)用場(chǎng)景,以及在vue中節(jié)流防抖的具體實(shí)現(xiàn)操作
- js防抖函數(shù)和節(jié)流函數(shù)使用場(chǎng)景和實(shí)現(xiàn)區(qū)別示例分析
- JS防抖和節(jié)流實(shí)例解析
- JS中的防抖與節(jié)流及作用詳解
- JS函數(shù)節(jié)流和防抖之間的區(qū)分和實(shí)現(xiàn)詳解
- js防抖和節(jié)流的深入講解
- JS函數(shù)節(jié)流和函數(shù)防抖問題分析
- JavaScript函數(shù)節(jié)流和函數(shù)防抖之間的區(qū)別
- JavaScript 防抖和節(jié)流遇見的奇怪問題及解決
相關(guān)文章
學(xué)習(xí)JavaScript編程語(yǔ)言的8張思維導(dǎo)圖分享
這篇文章主要介紹了學(xué)習(xí)JavaScript編程語(yǔ)言的8張思維導(dǎo)圖分享,本文給出了javascript變量、javascript運(yùn)算符、javascript數(shù)組、javascript流程語(yǔ)句、javascript字符串函數(shù)、javascript函數(shù)基礎(chǔ)、javascript基礎(chǔ)DOM操作、javascript正則表達(dá)式的思維導(dǎo)圖,需要的可以參考下2015-03-03JS實(shí)現(xiàn)具備延時(shí)功能的滑動(dòng)門菜單效果
這篇文章主要介紹了JS實(shí)現(xiàn)具備延時(shí)功能的滑動(dòng)門菜單效果,涉及JavaScript基于鼠標(biāo)事件與時(shí)間函數(shù)實(shí)現(xiàn)頁(yè)面樣式延遲變換功能,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-09-09學(xué)習(xí)drag and drop js實(shí)現(xiàn)代碼經(jīng)典之作
今天讀John Resig的Pro Javascript Techniques時(shí)候看到他書上給的一個(gè)關(guān)于drag and drop的例子, 合上書本自己寫一個(gè)簡(jiǎn)化版本的。大約20分鐘完成, 沒有考慮兼容firefox。整個(gè)代碼封裝成一個(gè)對(duì)象 也是借鑒書中的風(fēng)格。我覺得很好。2009-04-04學(xué)習(xí)JavaScript設(shè)計(jì)模式(鏈?zhǔn)秸{(diào)用)
這篇文章主要帶領(lǐng)大家學(xué)習(xí)JavaScript設(shè)計(jì)模式,其中重點(diǎn)介紹鏈?zhǔn)秸{(diào)用,感興趣的小伙伴們可以參考一下2015-11-11JS+CSS實(shí)現(xiàn)模仿瀏覽器網(wǎng)頁(yè)字符查找功能的方法
這篇文章主要介紹了JS+CSS實(shí)現(xiàn)模仿瀏覽器網(wǎng)頁(yè)字符查找功能的方法,實(shí)例分析了javascript實(shí)現(xiàn)查找功能的樣式及相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-02-02uniapp實(shí)現(xiàn)地圖點(diǎn)聚合功能的詳細(xì)教程
最近公司項(xiàng)目需求需要對(duì)設(shè)備在地圖上面進(jìn)行監(jiān)控,并在當(dāng)設(shè)備一定距離時(shí)進(jìn)行聚合,這篇文章主要給大家介紹了關(guān)于uniapp實(shí)現(xiàn)地圖點(diǎn)聚合功能的相關(guān)資料,需要的朋友可以參考下2022-12-12Javscript調(diào)用iframe框架頁(yè)面中函數(shù)的方法
這篇文章主要介紹了Javscript調(diào)用iframe框架頁(yè)面中函數(shù)的方法,可實(shí)現(xiàn)iframe之間傳值或修改值,是非常實(shí)用的技巧,需要的朋友可以參考下2014-11-11