首頁 >web前端 >js教程 >什麼時候應該在 JavaScript `setTimeout` 函數呼叫中使用括號?

什麼時候應該在 JavaScript `setTimeout` 函數呼叫中使用括號?

DDD
DDD原創
2024-11-23 04:34:21538瀏覽

When Should I Use Parentheses in JavaScript `setTimeout` Function Calls?

何時在函數呼叫中使用括號

在提供的程式碼片段中:

var myFunction = function() {
   setTimeout(myFunction, 1000);
}
myFunction();

內的函數呼叫setTimeout 不需要括號,因為setTimeout 需要函數參考作為參數。 myFunction 引用函數。

相反,最後一行中的 myFunction() 呼叫此函數。當 myFunction 使用括號時,它會呼叫該函數並執行其程式碼。

規則的例外

在某些情況下,setTimeout(myFunction(), 1000)可能有道理。例如,如果myFunction() 傳回一個函數本身:

function myFunction() {
    return function() {
        alert("ohai")
    }
}

在這種情況下,setTimeout(myFunction(), 1000) 執行下列操作:

    呼叫myFtion 函數,它會傳回顯示警報的匿名函數。
  • 將傳回的函數設定為參數setTimeout。
因此每秒都會觸發一次警報。

以上是什麼時候應該在 JavaScript `setTimeout` 函數呼叫中使用括號?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn