Die asynchrone Natur von JavaScript stellt oft eine Herausforderung dar, Rückgabewerte sofort zu erhalten. Betrachten Sie in diesem Zusammenhang eine jQuery-Funktion, die einen GUID-Wert über einen asynchronen Aufruf abruft. Während die Funktion „alert()“ innerhalb der Funktion die GUID erfolgreich anzeigt, hat es sich für viele Entwickler als schwierig erwiesen, sie einer Variablen zuzuweisen und ihren Wert zurückzugeben.
Ein gängiger Ansatz für dieses Problem ist die Einführung einer Rückruffunktion als Parameter. Diese Methode stellt sicher, dass die Funktion nach Abschluss des asynchronen Aufrufs ein verzögertes Versprechen zurückgibt, sodass Rückrufe daran angehängt werden können.
function trackPage() { var elqTracker = new jQuery.elq(459), dfd = $.Deferred(); elqTracker.pageTrack({ success: function() { elqTracker.getGUID(function(guid) { dfd.resolve(guid); }); } }); return dfd.promise(); } // Example usage: trackPage().done(function(guid) { alert("Got GUID: " + guid); });
In diesem Beispiel gibt die Funktion trackPage() jetzt ein Versprechen zurück. Mit der Methode done() kann eine Rückruffunktion angehängt werden, um den GUID-Wert zu empfangen, sobald der asynchrone Aufruf abgeschlossen ist. Mehrere Rückrufe können miteinander verkettet werden.
var pageHit = trackPage().done(function(guid) { alert("Page Hit GUID: " + guid); }); $("button").click(function() { pageHit.done(function(guid) { alert("Clicked on Page GUID: " + guid); }); });
Das von jQuery bereitgestellte $.Deferred-Objekt ermöglicht es Entwicklern, ihre eigene asynchrone Logik zu erstellen, die Versprechen zurückgibt und so eine konsistente Schnittstelle in der gesamten Anwendung gewährleistet. Andere jQuery-Module wie AJAX geben ebenfalls Versprechen zurück, was die Handhabung asynchroner Vorgänge in JavaScript erleichtert.
Das obige ist der detaillierte Inhalt vonWie erhalte ich Rückgabewerte von asynchronen JavaScript-Funktionen mit jQuery?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!