setTimeout居然還有第三個參數?
setTimeout居然還有第三個參數?
說起setTimeout,各位再熟悉不過,用法也很簡單:setTimeout(fun, delay)。
但說起來你可能不信,用了這麼多年的setTimeout居然有第三個參數。下面一起來看看這個setTimeout第三個參數。
【相關課程推薦:JavaScript影片教學】
#我們先來看一段簡單的程式碼:
setTimeout(function(x) { console.log(x); }, 1000, 1);
主機輸出1,那麼能不能繼續加參數呢?我們繼續來看下面這段程式碼:
setTimeout(function(x,y) { console.log(x+y); }, 1000, 1, 2);
控制台輸出的是3,很顯然是第三和第四個參數的和。
看到這裡很多小夥伴應該意識到了,是的,setTimeout的第三個參數作用就是給setTimeout第一個函數的參數。
透過查詢MDN https://developer.mozilla.org/en-US/docs/Web/API/WindowOrWorkerGlobalScope/setTimeout 我們能看到第三個參數的描述:
var timeoutID = scope.setTimeout(function[, delay, arg1, arg2, ...]); var timeoutID = scope.setTimeout(function[, delay]); var timeoutID = scope.setTimeout(code[, delay]);
所以,其實要準確來講,setTimeout可以有無數個參數,只是從第三個參數起,就是可選參數了。
好了,知道這個特性後我們可以解決什麼問題呢?最經典的一個就是for迴圈內使用setTimeout了。
for(var i = 0; i<6; i++) { setTimeout(function() { console.log(i); }, 1000); }
上面的這個例子是一個經典的面試題,它會連續輸出6次6,因為setTimeout是一個非同步操作,而等到執行setTimeout時,for迴圈已經執行完畢,這時的i已經等於6,所以輸出6次的6。關於解決方法我總結了好幾種,有興趣的夥伴可以看我的上一篇部落格《關於for循環中使用setTimeout》,在這篇部落格結尾我提到了使用setTimeout第三個參數,那我們再來看看這種方法。
for(var i=0;i<6;i++) { setTimeout(function(j) { console.log(j); }, 1000, i); }
由於每次傳入的參數是從for迴圈裡面取到的值,所以會依序輸出0~5。這當然還是作用域的問題,但是這裡setTimeout第三個參數卻把i的值給保存了下來。這種解決方法比使用閉包輕快的多。
另外,第三個參數也可以當作函數來使用。
for(var i=0;i<6;i++) { setTimeout(function(j) { console.log(j); }, 1000, i); }
最後依序輸出為,第一次0、第二次1。
可以看到第三個參數還可以先執行,然後再執行函數。
最後,使用第三個參數要注意的一點就是相容問題,如果需要相容IE9及以前的版本,需要引入一段MDN提供的相容舊IE程式碼 https://developer.mozilla .org/zh-CN/docs/Web/API/Window/setTimeout#相容舊環境(polyfill),這裡貼出傳送門,有興趣的可以去看。
以下是MDN上關於相容性的描述:
Note: Passing additional arguments to the function in the first syntax does not work in Internet Explorer 9 and below. If you want to enable this functionality on that browser, you must use a polyfill (see the Polyfill section).
本文來自 js教學 欄目,歡迎學習!
以上是setTimeout居然還有第三個參數?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

PHP5.4版本新功能:如何使用callable類型提示參數接受可呼叫的函數或方法引言:PHP5.4版本引入了一個非常便利的新功能-可以使用callable類型提示參數來接受可呼叫的函數或方法。這個新功能使得函數和方法可以直接指定對應的可呼叫參數,而無需進行額外的檢查和轉換。在本文中,我們將介紹callable類型提示的使用方法,並提供一些程式碼範例,

產品參數是指產品屬性的意思。例如服裝參數有品牌、材質、型號、大小、風格、布料、適應人群和顏色等;食品參數有品牌、重量、材質、衛生許可證號碼、適應人群和顏色等;家電參數有品牌、尺寸、顏色、產地、適應電壓、訊號、介面和功率等。

C++參數類型安全檢查透過編譯時檢查、執行時間檢查和靜態斷言確保函數只接受預期類型的值,防止意外行為和程式崩潰:編譯時類型檢查:編譯器檢查類型相容性。運行時類型檢查:使用dynamic_cast檢查類型相容性,不符則拋出異常。靜態斷言:在編譯時對型別條件進行斷言。

在開發過程中,我們可能會遇到這樣一個錯誤提示:PHPWarning:in_array()expectsparameter。這個錯誤提示會在使用in_array()函數時出現,有可能是因為函數的參數傳遞不正確所導致的。以下我們來看看這個錯誤提示的解決方法。首先,需要明確in_array()函數的作用:檢查一個值是否在陣列中存在。此函數的原型為:in_a

雙曲函數是使用雙曲線而不是圓定義的,與普通三角函數相當。它從提供的弧度角傳回雙曲正弦函數中的比率參數。但要做相反的事,或者換句話說。如果我們想要根據雙曲正弦值計算角度,我們需要像雙曲反正弦運算一樣的反雙曲三角運算。本課程將示範如何使用C++中的雙曲反正弦(asinh)函數,並使用雙曲正弦值(以弧度為單位)計算角度。雙曲反正弦運算遵循下列公式-$$\mathrm{sinh^{-1}x\:=\:In(x\:+\:\sqrt{x^2\:+\:1})},其中\:In\:是\:自然對數\:(log_e\:k)

i9-12900H是14核心的處理器,使用的架構和工藝都是全新的,線程也很高,整體的工作都是很優秀的,一些參數都有提升特別的全面,是可以給用戶們帶來極佳體驗的。 i9-12900H參數評測大全評測:1、i9-12900H是14核心的處理器,採用了q1架構以及24576kb的製程工藝,提升到了20個執行緒。 2.最大的CPU頻率是1.80!5.00ghz,整體主要取決於工作的負載。 3.相比較價位來說還是特別合適的,性價比很不錯,對於一些需要正常使用的伙伴來說非常的合適。 i9-12900H參數評測大全性能跑分

大型語言模型(LLM)雖然性能強勁,但動輒幾百上千億的參數量,對計算設備還是內存的需求量之大,都不是一般公司能承受得住的。量化(Quantization)是常見的壓縮操作,透過降低模型權重的精度(如32bit降為8bit),犧牲一部分模型的效能來換取更快的推理速度,更少的記憶體需求。但對於超過1000億參數量的LLM來說,現有的壓縮方法都無法維持模型的準確率,也無法在硬體上有效率地運作。最近,麻省理工學院和英偉達的研究人員聯合提出了一個通用後訓練的量化(GPQ, general-purpose po

能打得過GPT-4的開源模型出現了!大模型競技場最新戰報:1040億參數開源模型CommandR+攀升至第6位,與GPT-4-0314打成平手,超過了GPT-4-0613。圖片這也是第一個在大模型競技場上擊敗GPT-4的開放權重模型。大模型競技場,可是大神Karpathy口中唯二信任的測試基準之一。圖片CommandR+來自AI獨角獸Cohere。這家大模型新創公司的共同創辦人兼CEO,正是Transformer最年輕作者AidanGomez(簡稱割麥子)。圖片這份戰報一出,又掀起了一波大模型社
