精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

JavaScript setTimeout 延遲不準?原理和解決方法詳解

開發 前端
很多剛開始用 JavaScript 的開發者,會覺得 setTimeout 是個讓代碼“等會兒再跑”的簡單工具。但實際用起來,常常發現它不那么聽話:明明設定了1秒后執行,結果卻等了好幾秒才來,或者干脆沒動靜。這篇文章就講講 setTimeout 到底是怎么工作的,以及為什么它有時會“遲到”或“缺席”,幫你避免常見的坑。

很多剛開始用 JavaScript 的開發者,會覺得 setTimeout 是個讓代碼“等會兒再跑”的簡單工具。

但實際用起來,常常發現它不那么聽話:明明設定了1秒后執行,結果卻等了好幾秒才來,或者干脆沒動靜。

這背后的原因,弄明白了其實也不復雜。這篇文章就講講 setTimeout 到底是怎么工作的,以及為什么它有時會“遲到”或“缺席”,幫你避免常見的坑。

1. 最基礎的誤解:setTimeout(fn, 1000) 不等于“1秒后準時執行”

別被參數名字騙了。setTimeout 的真實意思是:“至少等1000毫秒后,把這個函數 fn 放進一個待辦事項列表(任務隊列)里排隊。等當前手頭所有活兒都干完了,再輪到它執行。”

看個簡單例子就懂了:

console.log("開始");
setTimeout(() => { console.log("定時器到了!"); }, 0); // 延遲設為0
console.log("結束");

輸出順序是:

開始
結束
定時器到了!

為什么 0 秒延遲也沒立刻執行?因為 setTimeout 的回調函數(就是那個打印“定時器到了!”的函數)被放進隊列后,必須等到當前正在跑的代碼(就是打印“開始”和“結束”的那段)全部執行完畢,主線程閑下來了,才會去隊列里把它拿出來執行。即使延遲是0,也要排隊。

2. 主線程忙不過來,定時器就得一直等(延遲漂移)

JavaScript 在一個線程里干活(單線程)。如果這個線程被其他事情卡住了,setTimeout 設定的時間到了也沒用,回調函數只能在隊列里干等著。

看這個例子:

console.log("開始");

setTimeout(() => { console.log("Timeout!"); }, 1000); // 計劃1秒后執行

const startTime = Date.now();
while (Date.now() - startTime < 3000) { // 模擬一個耗時3秒的復雜計算
// 這里啥也不干,就是空等3秒,占住主線程
}

console.log("結束");

輸出順序和大概時間是:

開始
(這里卡頓3秒...)
結束
Timeout! (在 "開始" 打印后大約3秒多才出現)

雖然我們設定了1秒后執行 console.log("Timeout!"),但主線程被那個 while 循環死死占住了整整3秒。

定時器的時間(1秒)到了,回調函數被放進了隊列,但只能眼巴巴等著主線程空閑。

直到3秒后循環結束,打印了“結束”,主線程才空閑下來,這時它才去隊列里拿出回調函數執行。結果就是,1秒的延遲實際變成了3秒多。這就是所謂的“延遲漂移”。

3. 用 setTimeout 搞循環定時?小心誤差越來越大

有時候你想每隔1秒重復做點事,可能這樣寫:

functiondoSomething() {
console.log("干活了...");
// 假設這里可能也有點耗時操作...
setTimeout(doSomething, 1000); // 干完再計劃下一次
}
doSomething(); // 啟動

這個寫法的問題是:setTimeout 是在 doSomething 函數執行完之后,才計劃下一次執行。

如果 doSomething 函數本身執行需要時間(比如200毫秒),那么兩次執行之間的間隔就變成了 1000毫秒 + 200毫秒 = 1200毫秒。時間一長,這個誤差會累積,定時就越來越不準了。

想更準一點怎么辦?

setInterval: 這個函數就是設計來重復執行的。它會嘗試每隔指定的時間(比如1000ms)就把回調函數放進隊列一次。

但是,它有個問題叫“累積效應”:如果回調執行時間比間隔時間長,那么下一次回調會立刻執行(或者連續堆積起來),而不是等間隔時間。所以它也不是絕對精確。

requestAnimationFrame (做動畫首選): 瀏覽器專門為流暢動畫設計的。它會在每次屏幕刷新前調用你的函數(通常是每秒60次)。

用它做動畫最合適,能保證流暢度,并且瀏覽器在標簽頁不可見時會自動暫停,省資源。

基于時間差計算: 對于需要精確時間間隔但又不能用 requestAnimationFrame 的情況(比如不是動畫),可以在每次回調里記錄實際過去的時間,然后計算下一次需要執行的時間點。這能減少累積誤差。

4. 我的定時器怎么根本沒執行?

如果 setTimeout 的回調函數壓根沒跑,通常不是語法錯誤,而是這些情況:

頁面或組件卸載了: 在 react, vue 這些框架里,如果你在一個組件里設置了定時器,但組件被銷毀(比如頁面跳轉、組件隱藏)時沒清除它,定時器雖然可能還在,但回調函數執行時組件狀態可能已經無效了,導致看起來沒執行,甚至報錯。

關鍵:組件卸載前務必用 clearTimeout 清理定時器!

被清除了: 你或者某個庫的代碼主動調用了 clearTimeout,傳入了正確的定時器ID。

瀏覽器標簽頁在后臺: 為了省電和省資源,現代瀏覽器(Chrome, Firefox, Safari 等)會對后臺標簽頁(不是當前你看的那個標簽)里的定時器進行“節流”。

延遲很短(比如幾秒)的定時器可能被延遲執行,非常短的(如動畫用的)可能被暫停。

Chrome 對后臺標簽頁的非活動定時器,延遲時間可能被限制到至少1分鐘(1000ms以上)甚至更長(如10分鐘)!當你切回標簽頁時,它們才會被處理。

環境不同: 你的代碼可能運行在 Web Worker 或 Node.js 環境里,它們處理定時器的機制和瀏覽器主線程不完全一樣。

5. 循環里的定時器和閉包陷阱(為什么都打印5?)

這是一個非常經典的坑:

for(vari=0;i<5;i++) {
setTimeout(function() {
console.log(i);//期待0,1,2,3,4?實際輸出:5,5,5,5,5
    }, 1000);
}

為什么輸出5個5?

var 聲明的 i 是函數作用域(在這個例子里相當于全局作用域),不是塊級作用域。

循環飛快地跑了5次,創建了5個定時器(都設定了1秒后執行)。

循環結束后,i 的值已經是 5。

1秒后(或者更久,看主線程忙不忙),5個定時器的回調函數開始執行。

它們訪問的都是循環結束后同一個 i,也就是 5。

怎么修?兩種常用方法:

用 let(推薦): let 是塊級作用域。每次循環都會創建一個新的 i,每個定時器回調都綁定了自己循環那次的那個 i 的值。

for (let i = 0; i < 5; i++) { // 關鍵:把 var 改成 let
setTimeout(function() {
console.log(i); // 正確輸出:0, 1, 2, 3, 4
    }, 1000);
}

用 IIFE(立即執行函數表達式)創建作用域: 如果你不得不用 var,可以用 IIFE 在每次循環時創建一個新的作用域,把當前的 i 值“鎖”住。

for (var i = 0; i < 5; i++) {
    (function(j) { // j 捕獲了當前循環的 i 值
setTimeout(function() {
console.log(j); // 正確輸出:0, 1, 2, 3, 4
        }, 1000);
    })(i); // 立即調用,把當前的 i 傳進去作為 j
}

總結:理解 setTimeout 的關鍵點

核心概念

解釋說明

不是倒計時器

setTimeout(fn, 1000) 意思是“至少等1000毫秒后,把 fn 放進任務隊列”,不是“1000毫秒后準時執行”。

要排隊等空閑

放進隊列的 fn,必須等當前所有代碼執行完(主線程空閑)才會被執行。

主線程是老大

如果主線程被其他任務(復雜計算、長循環、渲染)卡住,定時器回調就得一直等著,導致“延遲漂移”。

循環里有坑(var)

在 for 循環里用 var 配合 setTimeout,所有回調會共享循環結束后的變量值。用 let 或 IIFE 解決。

后臺會被限制

瀏覽器會大幅延遲后臺標簽頁的定時器執行(節能),可能導致回調長時間不執行。

用完要清理

在單頁應用(SPA)或組件中,組件卸載前必須用 clearTimeout 清除定時器,避免錯誤或內存泄漏。

簡單說:別把 setTimeout(fn, 1000) 理解成“請1秒后執行這個函數”。

它其實是說:“1秒后,把這個函數加到待辦事項里,等手頭沒活了再處理它?!?手頭有沒有活、活多不多、瀏覽器標簽是不是在前臺,都會影響它最終執行的時間。

理解了這一點,再用 setTimeout 就能避開大部分坑了。

責任編輯:龐桂玉 來源: web前端開發
相關推薦

2019-11-21 16:26:44

Windows電腦瀏覽器

2020-06-27 08:57:55

HTTP403服務器

2010-06-17 11:17:34

裝系統出現Grub

2010-08-24 11:34:37

DIV+CSS

2010-06-09 09:39:42

Opensuse雙系統

2011-05-26 11:38:23

重復頁

2010-02-24 16:30:52

WCF常見錯誤

2010-08-12 09:30:08

Flex內存泄露

2013-10-23 11:22:47

HadoopHadoop處理大量小

2013-10-23 10:48:30

HadoopHDFS文件處理

2018-08-28 08:47:09

服務器宕機方法

2010-12-27 11:00:53

Virtualbox

2010-03-08 09:29:09

Linux Debia

2017-05-04 14:37:38

Windows故障方法

2011-07-05 09:44:31

QT Mysql 亂碼

2011-09-08 16:34:28

Windows7網絡延遲

2010-08-03 09:12:52

Flex安全沙箱

2017-06-14 22:11:57

數據庫MySQL死鎖

2010-02-26 15:53:35

WCF套接字連接中斷

2010-02-05 18:13:49

C++ sprintf
點贊
收藏

51CTO技術棧公眾號

波多野结衣家庭教师| 亚洲精品久久久蜜桃| 欧美午夜理伦三级在线观看| 国产传媒一区二区| 国产传媒免费在线观看| 波多野结衣久久精品| 自拍偷拍欧美专区| 欧美日韩一区久久| 日日骚一区二区网站| 99久久久久久久久| 秋霞蜜臀av久久电影网免费| 亚洲高清不卡在线观看| 99久热re在线精品视频| 成年人一级黄色片| 九色丨蝌蚪丨成人| 午夜电影一区二区| 国产一区二区在线网站| 九九热视频精品| 久久伊人精品| 一区二区三区在线视频观看58| 精品久久久久久乱码天堂| 国产在线一区视频| 国产精品15p| 亚洲一二三四在线| 国产伦精品一区二区三| 国产无遮挡又黄又爽在线观看| 狠狠色丁香婷婷综合影院| 一本久久精品一区二区| 欧美一区少妇| 一级久久久久久| 欧美精品尤物在线观看| 欧美在线观看一区| 东北少妇不带套对白| 色婷婷av一区二区三区之红樱桃 | 久88久久88久久久| 在线日韩欧美视频| 伊人成人222| 黄色网在线免费看| 久久久久久久久久久久久久| 欧美日韩国产成人在线91| 亚洲精品9999| 国产亲伦免费视频播放| 欧美精品一卡| 亚洲精品电影久久久| 激情六月丁香婷婷| 一本一道波多野毛片中文在线| 日本不卡视频一二三区| 久久韩国免费视频| 亚洲欧美激情一区二区三区| 超级碰碰不卡在线视频| 26uuu精品一区二区三区四区在线| 欧美一级在线亚洲天堂| 一级性生活大片| 成人福利一区二区| 一片黄亚洲嫩模| 牛人盗摄一区二区三区视频| 一卡二卡在线观看| 狠狠干成人综合网| 国产亚洲精品久久久久久牛牛| 色一情一区二区| 欧美性www| 亚洲午夜日本在线观看| 成人av在线播放观看| 黄网在线观看| 国产91精品在线观看| 欧美在线中文字幕| 激情五月婷婷小说| 激情文学一区| 日韩在线视频观看正片免费网站| 性色av浪潮av| 年轻的保姆91精品| 精品少妇一区二区三区在线播放| 亚洲人成无码www久久久| 国精产品一区| 亚洲精品老司机| 国产3p露脸普通话对白| 久久亚洲天堂| 夜夜嗨av一区二区三区网页| www.在线观看av| 1pondo在线播放免费| 99久久综合国产精品| 91精品啪aⅴ在线观看国产| 日本三级小视频| 91精品秘密在线观看| 久久在线免费观看视频| 免费污网站在线观看| 日韩免费福利视频| 亚洲成人在线观看视频| 欧美成人免费高清视频| 欧美一区=区三区| 精品国产免费久久 | 农村黄色一级片| 亚洲丁香日韩| 亚洲国产欧美一区二区三区同亚洲 | xnxx国产精品| 色中文字幕在线观看| 香蕉av在线播放| 国产伦精品一区二区三区视频青涩 | 亚洲精品久久久久久久久| 在哪里可以看毛片| 一区二区电影| 日本欧美国产在线| 日韩欧美激情视频| 在线高清一区| 国产精品白丝jk喷水视频一区| 欧美另类一区二区| 狠狠狠色丁香婷婷综合激情| 国产精品久久久| 国产成人精品无码高潮| 精品中文字幕一区二区| 国产日韩精品推荐| 麻豆视频网站在线观看| 国产精品久久久久久亚洲毛片| 欧美精品一区二区三区四区五区 | 中文字幕乱码中文乱码51精品| 亚洲激情中文1区| 成人午夜视频免费在线观看| 久久天堂久久| 深夜福利91大全| www.com国产| 亚洲视频成人| 欧美在线视频网| 精品久久久久中文慕人妻| 国产精品影视网| 日本成人三级电影网站| 成人一级福利| 色婷婷综合久久久| 亚洲精品乱码久久| 国产精品三级| 91国产美女视频| 男人天堂av在线播放| 成人一区二区三区中文字幕| 精品国产乱码久久久久久蜜柚| √新版天堂资源在线资源| 色综合久久六月婷婷中文字幕| 国产吃瓜黑料一区二区| 国内精品麻豆美女在线播放视频| 日韩最新免费不卡| 欧美丰满艳妇bbwbbw| 麻豆高清免费国产一区| 亚洲中国色老太| 欧美性猛交 xxxx| 久久久亚洲国产美女国产盗摄| 青青草久久网络| 自拍视频在线看| 日韩精品在线观看网站| 人成免费在线视频| 亚洲欧美一级二级三级| 性欧美xxxx视频在线观看| 天天干,天天干| 国产一区二区三区在线观看精品| 国产精品视频免费观看| 亚洲国产精品精华素| 精品毛片网大全| 思思久久精品视频| 日韩超碰人人爽人人做人人添| 中国china体内裑精亚洲片| 在线观看成人毛片| 国产成人精品综合在线观看| 欧美精品亚洲精品| 成人免费福利| 精品播放一区二区| 日本五十熟hd丰满| 麻豆免费精品视频| 中文字幕av日韩精品| 国产乱码精品一区二三赶尸艳谈| 精品国产乱码久久久久久1区2区| 九九视频免费观看| 99久久久国产精品免费蜜臀| 18禁男女爽爽爽午夜网站免费| 自拍亚洲一区| 国产精品网站大全| 天天操天天干天天| 日韩欧美国产高清91| 九色91porny| 亚洲激情另类| 91传媒视频在线观看| 国产三级在线观看| 午夜不卡在线视频| xxxx日本黄色| 一本久道久久综合婷婷鲸鱼| 91视频免费在线| 黄色大片在线| 亚洲免费av网址| 日本熟妇色xxxxx日本免费看| 99精品国产一区二区三区不卡| 中文字幕av久久| 开心激情综合| 国产精品欧美日韩| 国产视频三级在线观看播放| 欧美精品日日鲁夜夜添| av黄色在线免费观看| 国产精品视区| 亚洲视频sss| 日韩精品麻豆| 国产亚洲欧洲在线| 99精品在线视频观看| 懂色av中文一区二区三区天美| 手机免费看av片| 欧美日韩调教| 日本一区二区三区在线视频| 久久视频免费| 国产精品久久9| av中文资源在线资源免费观看| 日韩欧美一区二区免费| 国产一区二区精彩视频| 99在线精品免费| 国产在线观看中文字幕| 亚洲mv大片欧洲mv大片| 久久久久久久久一区二区| 国产在线观看www| 日韩一区二区三区xxxx| 日本私人网站在线观看| 一本一道久久a久久精品综合蜜臀 一本一道综合狠狠老 | 国产精品16p| 亚洲天堂免费在线观看视频| 一级特黄性色生活片| 波多野结衣在线观看一区二区| 欧美一区二区影院| 性欧美videos高清hd4k| 自拍偷拍亚洲一区| 国产综合在线观看| 亚洲精品91美女久久久久久久| 国产精品久久久久久免费免熟| 中文字幕一区二区三区在线不卡| 成人不卡免费视频| 久久久久国产精品一区二区| 日韩精品另类天天更新| 国产一区二区三区影视| 国语自产精品视频在线看| 日韩电影免费| 国产精品久久久久一区二区三区厕所| 校园春色另类视频| 国产精品久久久久久久久久久久| 精精国产xxxx视频在线野外| 欧美疯狂做受xxxx高潮| 色呦呦中文字幕| 欧美一级二级在线观看| 久久久久99精品| 亚洲乱码日产精品bd| 中文文字幕文字幕高清| 久久蜜桃资源一区二区老牛| 亚洲欧美日韩精品久久久| 亚洲品质自拍| 欧美不卡在线一区二区三区| 性欧美lx╳lx╳| 精品一区二区日本| 亚洲毛片免费看| 欧美伦理一区二区| 精品久久美女| 亚洲三区在线| 亚洲a在线视频| 国产a级黄色大片| 激情欧美亚洲| 少妇性饥渴无码a区免费| 国产手机视频一区二区| 日韩毛片在线免费看| 日本中文字幕一区二区视频| 欧美一级特黄a| 一区免费在线| 97成人在线免费视频| 国产日韩三级| 久久精品国产第一区二区三区最新章节 | 久久免费精品国产| 不卡免费追剧大全电视剧网站| 成年人免费大片| 日本欧洲一区二区| 制服丝袜中文字幕第一页| 国产激情91久久精品导航| youjizz.com国产| 久久免费午夜影院| 国产视频精品视频| 91在线视频官网| 亚洲一二三四视频| 亚洲最大的成人av| 一级片在线观看免费| 678五月天丁香亚洲综合网| 欧美国产成人精品一区二区三区| 色婷婷精品久久二区二区蜜臂av | 精品国产露脸精彩对白| 你懂的在线播放| 亚洲国模精品私拍| 都市激情一区| 欧美黄色片免费观看| a日韩av网址| 91在线观看免费高清| 三级小说欧洲区亚洲区| 亚洲一区二区三区精品视频 | 欧美日本中文字幕| 日本在线免费播放| 欧美精品18videosex性欧美| av中文字幕在线观看| www.欧美三级电影.com| 2018av在线| 国产在线播放不卡| 欧美午夜三级| 国产精品久久久久免费a∨大胸 | 国产欧美韩日| 日韩久久综合| 先锋影音网一区| 欧美黄免费看| 国产一线二线三线在线观看| 国产成人综合在线| 欧美午夜激情影院| 亚洲aaa精品| 国产农村妇女毛片精品| 尤物yw午夜国产精品视频明星| brazzers在线观看| 91日本在线视频| 欧美色图一区| 免费毛片小视频| 久久狠狠婷婷| 波多野吉衣在线视频| 国产精品久久久久一区二区三区 | 在线播放国产精品二区一二区四区| 欧美 日韩 国产 精品| 久久深夜福利免费观看| 视频精品导航| 欧美在线一区二区三区四区| 亚洲精一区二区三区| 亚洲三级在线视频| 懂色av一区二区在线播放| 国产18无套直看片| 欧美视频在线免费看| 黄片毛片在线看| 亚洲精品国产欧美| 男人添女人下部高潮视频在线观看| 久久久久久久久久久国产| 成人网av.com/| 国产伦精品一区二区三区| 婷婷亚洲最大| 天天影视色综合| 欧美国产日产图区| 欧美人妻精品一区二区三区| 欧美日韩国产系列| 在线免费看av| 国产美女精品视频免费观看| 黑人操亚洲人| 亚洲欧美在线精品| 中文字幕av资源一区| 最新在线中文字幕| 日韩精品一区二区三区老鸭窝| 日本网站在线免费观看视频| 国产精品视频xxx| 久久在线视频免费观看| 日本xxxxxxxxxx75| 国产91精品免费| 国产在线观看免费av| 亚洲精品在线电影| 蜜桃视频在线观看免费视频| 91精品国产自产在线| 久久国产精品亚洲人一区二区三区| www.超碰com| 成人国产在线观看| 亚洲国产精一区二区三区性色| 日韩免费性生活视频播放| 超碰97免费在线| 欧美日韩高清在线一区| 日韩精品成人一区二区在线| 黑人无套内谢中国美女| 亚洲成人你懂的| 免费在线超碰| 国产区精品视频| 欧美激情第10页| 免费在线观看成年人视频| 亚洲综合一区二区| 天堂成人在线| 久久久久久久久久国产精品| 啪啪国产精品| 九色91popny| 亚洲美女屁股眼交3| 日韩一级免费毛片| 国产成人小视频在线观看| 国内精品麻豆美女在线播放视频 | 激情图区综合网| 精品午夜福利视频| 欧美日韩aaa| 欧美一卡二卡| 欧美专区一二三| 国产美女在线精品| 精品国产乱码一区二区| 中文字幕精品久久| 大型av综合网站| 欧美两根一起进3p做受视频| 亚洲六月丁香色婷婷综合久久 | 亚洲视频久久久| 亚洲人成电影在线| 性爽视频在线| 在线观看视频黄色| 91色视频在线| av一区二区三| 国产精品www网站| 精品二区视频| 黄色av片三级三级三级免费看| 日韩欧美精品网站| 国内精品久久久久国产| 麻豆成人小视频| 国精品**一区二区三区在线蜜桃| 国产美女激情视频| 欧美日本中文字幕|