使用jQuery 在JavaScript 中進行非同步值檢索
在JavaScript 中,管理非同步程式碼可能具有挑戰性,尤其是在嘗試檢索和分配回傳值時。考慮以下 jQuery 函數:
雖然alert() 函數正確顯示 GUID 值,但將其指派給變數 someGuid 會導致未定義的值。這是由於 jQuery 的 getGUID() 方法的非同步特性。
非同步調用的本質
非同步調用,如範例中的調用,獨立執行主程式流程。當呼叫 getGUID() 方法時,它會立即執行並在結果可用之前傳回。因此,returnValue 變數被指派為未定義。
替代解決方案
要解決此問題,可以使用多種方法:
1.回呼函數
依照dfsq 的建議,回呼函數提供了一種傳遞將接收非同步呼叫結果的函數的機制。然而,當需要多個巢狀回呼函數時,這種方法可能會變得複雜。
2. jQuery $.Deferred
jQuery 的 $.Deferred 物件允許自訂非同步邏輯傳回承諾。 Promise 使回調能夠附加到非同步呼叫的結果,而不需要深層巢狀。下面更新的程式碼示範了這種方法:
將回調附加到 Promise 可以提供更大的靈活性並允許更有組織的程式碼。透過返回 Promise,其他程式碼也可以消費並等待非同步呼叫的結果。
以上是如何使用 jQuery 在 JavaScript 中檢索非同步值?的詳細內容。更多資訊請關注PHP中文網其他相關文章!