同步執行非同步 JavaScript 函數
在某些情況下,可能需要同步執行非同步 JavaScript 函數,但不會凍結 UI 。雖然這通常不被認為是好的做法,但在某些特定情況下可能被認為是必要的。
挑戰
目標是阻止函數直到回調被調用,而不凍結 UI。這提出了一個挑戰,因為阻止 JavaScript 通常會導致 UI 凍結。
可能的解決方案
一個可能的解決方案涉及使用輪詢來檢查回調設定的全域變數。以下是一個範例:
function doSomething() { // Callback sets received data to a global variable function callBack(d) { window.data = d; } // Start the async myAsynchronousCall(param1, callBack); } // Start the function doSomething(); // Clear the global data window.data = null; // Poll at an interval until data is found in the global var intvl = setInterval(function() { if (window.data) { clearInterval(intvl); console.log(data); } }, 100);
此方法允許呼叫函數阻塞,直到從回調接收到資料為止,而不會凍結 UI。但是,它假設可以修改 doSomething() 函數以使用全域變數。
最佳實務
需要注意的是,這種方法被認為是次優的解。理想情況下,非同步呼叫應該使用回調或承諾來處理,而不是阻塞函數。然而,在某些無法輕易修改的程式碼庫中,這可能是必要的臨時解決方法。
以上是非同步 JavaScript 函數能否同步執行而不凍結 UI?的詳細內容。更多資訊請關注PHP中文網其他相關文章!