Detaillierte Erläuterung des Deferred-Objekts von jQuery
deferredObject ist die jQuery-Schnittstelle zu Promises Es handelt sich um eine allgemeine Schnittstelle für asynchrone Vorgänge und kann als eine Aufgabe betrachtet werden, die darauf wartet, abgeschlossen zu werden. Tatsächlich spielt sie die Rolle eines Proxys Bestimmte einheitliche Merkmale sind Ajax-Operationen, Webseiten--Animationen , Web-Worker usw. Alle Ajax-Operationen
-Funktionen von jQueryWas sind Versprechen? Es dauert lange und andere Vorgänge müssen in die Warteschlange gestellt werden. Um zu vermeiden, dass das gesamte Programm nicht mehr reagiert, besteht die übliche Lösung darin, diese Vorgänge in der Form „
“ zu schreiben Rückruffunktion" (Rückruf) wie folgt. Obwohl es das Problem lösen kann, weist es einige erhebliche Mängel auf: 1. Rückruffunktionen werden oft in Form von
Funktionsparameterngeschrieben , was dazu führt, dass die Eingabe und Ausgabe der Funktion sehr verwirrend ist und das gesamte Programm nicht gelesen werden kann. 2 Wenn mehrere Operationen erforderlich sind Der gesamte laufende Prozess des Programms wird unterbrochen, Der Schwierigkeitsgrad steigt entsprechend.
Es wurde vorgeschlagen, diese Probleme zu lösen Ersetzen Sie Rückruffunktionen und werden Sie zu einer Lösung für asynchrone Operationen. Nehmen Sie beispielsweise an, dass die Ajax-Operation ein Promise-Objekt zurückgibt wie folgt: Dann verfügt das Promise-Objekt über eine Methode, mit der eine Rückruffunktion angegeben werden kann. Der Code lautet wie folgt :
kann die beiden oben genannten Codeausschnitte kombinieren, damit der Ablauf des Programms klarer erkennbar ist >
Der Code lautet wie folgt:
Ab Version 1.7 geben Ajax-Operationen Promise-Objekte direkt zurück, was bedeutet, dass die Callback-Funktion mit der then-Methode angegeben werden kann. Der Code lautet wie folgt:
var promise = get('http://www.example.com');
Methode des verzögerten Objekts
promise.then(function (content) { console.log(content) })
wird zum Generieren eines verzögerten Objekts verwendet.
get('http://www.example.com').then(function (content) { console.log(content) })
$.ajax({ url:"/echo/json/", success: function(response) { console.info(response.name); } });
Beide Methoden werden verwendet Rückruffunktion binden. done() gibt die Rückruffunktion an, nachdem der asynchrone Vorgang erfolgreich war, und fail() gibt die Rückruffunktion an, nachdem der asynchrone Vorgang fehlgeschlagen ist.
Der Code lautet wie folgt:
$.ajax({ url: "/echo/json/", }).then(function (response) { console.info(response.name); });
Sie geben das ursprüngliche verzögerte Objekt zurück, sodass Sie Kettenschreiben verwenden und dann andere Methoden (einschließlich „Done“ und „Fail“) darin verknüpfen können ).
resolve() und Reject()werden verwendet, um den
Status des zurückgestellten Objekts zu ändern. „resolve()“ ändert den Status in „Asynchroner Vorgang erfolgreich“ und „reject()“ ändert den Status in „Vorgangsfehler“.
Der Code lautet wie folgt:
var deferred = $.deferred();
Sobald „resolve()“ aufgerufen wird, werden die durch die Methoden „done()“ und „then()“ angegebenen Rückruffunktionen angezeigt nacheinander ausgeführt; sobald „reject“ aufgerufen wird (), werden die durch die Methoden „fail()“ und „then()“ angegebenen Rückruffunktionen nacheinander ausgeführt.
var deferred = $.Deferred(); deferred.done(function(value) { alert(value); });
Diese Methode hat drei Rückgabewerte:
progress() wird verwendet, um eine Rückruffunktion anzugeben, die ausgeführt wird, wenn die notify()-Methode aufgerufen wird. Sein Zweck besteht darin, eine Schnittstelle bereitzustellen, damit bestimmte Vorgänge während der Ausführung asynchroner Vorgänge ausgeführt werden können, z. B. die regelmäßige Rückgabe des Fortschritts desFortschrittsbalkens
.var deferred = $.Deferred(); deferred.done(function(value) { alert(value); }); deferred.resolve("hello world");
Der Code lautet wie folgt:
then()
then() wird auch verwendet, um die Rückruffunktion anzugeben , das drei Parameter, also drei Rückruffunktionen, akzeptieren kann. Der erste Parameter ist die Rückruffunktion, die beim Auflösen aufgerufen wird, der zweite Parameter ist die Rückruffunktion, die beim Zurückweisen aufgerufen wird, und der dritte Parameter ist die Rückruffunktion, die von der Methode progress() aufgerufen wird.
var deferred = new $.Deferred(); deferred.state(); // "pending"deferred.resolve(); deferred.state(); // "resolved"
deferred.then( doneFilter [, failFilter ] [, progressFilter ] )
在jQuery 1.8之前,then()只是.done().fail()写法的语法糖,两种写法是等价的。在jQuery 1.8之后,then()返回一个新的deferred对象,而done()返回的是原有的deferred对象。如果then()指定的回调函数有返回值,该返回值会作为参数,传入后面的回调函数。
代码如下:
var defer = jQuery.Deferred(); defer.done(function(a,b){ return a * b; }).done(function( result ) { console.log("result = " + result); }).then(function( a, b ) { return a * b; }).done(function( result ) { console.log("result = " + result); }).then(function( a, b ) { return a * b; }).done(function( result ) { console.log("result = " + result); }); defer.resolve( 2, 3 );
在jQuery 1.8版本之前,上面代码的结果是:
代码如下:
result = 2 result = 2 result = 2
在jQuery 1.8版本之后,返回结果是
代码如下:
result = 2 result = 6 result = NaN
这一点需要特别引起注意。
代码如下:
$.ajax( url1, { dataType: "json" } ) .then(function( data ) { return $.ajax( url2, { data: { user: data.userId } } ); }).done(function( data ) { // 从url2获取的数据 });
上面代码最后那个done方法,处理的是从url2获取的数据,而不是从url1获取的数据。
利用then()会修改返回值这个特性,我们可以在调用其他回调函数之前,对前一步操作返回的值进行处理。
代码如下:
var post = $.post("/echo/json/") .then(function(p){ return p.firstName; }); post.done(function(r){ console.log(r); });
上面代码先使用then()方法,从返回的数据中取出所需要的字段(firstName),所以后面的操作就可以只处理这个字段了。
有时,Ajax操作返回json字符串里面有一个error属性,表示发生错误。这个时候,传统的方法只能是通过done()来判断是否发生错误。通过then()方法,可以让deferred对象调用fail()方法。
代码如下:
var myDeferred = $.post('/echo/json/', {json:JSON.stringify({'error':true})}) .then(function (response) { if (response.error) { return $.Deferred().reject(response); } return response; },function () { return $.Deferred().reject({error:true}); } ); myDeferred.done(function (response) { $("#status").html("Success!"); }).fail(function (response) { $("#status").html("An error occurred"); });
always()
always()也是指定回调函数,不管是resolve或reject都要调用。
pipe方法
pipe方法接受一个函数作为参数,表示在调用then方法、done方法、fail方法、always方法指定的回调函数之前,先运行pipe方法指定的回调函数。它通常用来对服务器返回的数据做初步处理。
promise对象
大多数情况下,我们不想让用户从外部更改deferred对象的状态。这时,你可以在deferred对象的基础上,返回一个针对它的promise对象。我们可以把后者理解成,promise是deferred的只读版,或者更通俗地理解成promise是一个对将要完成的任务的承诺。
你可以通过promise对象,为原始的deferred对象添加回调函数,查询它的状态,但是无法改变它的状态,也就是说promise对象不允许你调用resolve和reject方法。
代码如下:
function getPromise(){ return $.Deferred().promise(); } try{ getPromise().resolve("a"); } catch(err) { console.log(err); }
上面的代码会出错,显示TypeError {} 。
jQuery的ajax() 方法返回的就是一个promise对象。此外,Animation类操作也可以使用promise对象。
代码如下:
var promise = $('p.alert').fadeIn().promise();
$.when()方法
$.when()接受多个deferred对象作为参数,当它们全部运行成功后,才调用resolved状态的回调函数,但只要其中有一个失败,就调用rejected状态的回调函数。它相当于将多个非同步操作,合并成一个。
代码如下:
$.when( $.ajax( "/main.php" ), $.ajax( "/modules.php" ), $.ajax( "/lists.php" ) ).then(successFunc, failureFunc);
上面代码表示,要等到三个ajax操作都结束以后,才执行then方法指定的回调函数。
when方法里面要执行多少个操作,回调函数就有多少个参数,对应前面每一个操作的返回结果。
代码如下:
$.when( $.ajax( "/main.php" ), $.ajax( "/modules.php" ), $.ajax( "/lists.php" ) ).then(function (resp1, resp2, resp3){ console.log(resp1); console.log(resp2); console.log(resp3); });
上面代码的回调函数有三个参数,resp1、resp2和resp3,依次对应前面三个ajax操作的返回结果。
when方法的另一个作用是,如果它的参数返回的不是一个Deferred或Promise对象,那么when方法的回调函数将 立即运行。
代码如下:
$.when({testing: 123}).done(function (x){ console.log(x.testing); // "123" });
上面代码中指定的回调函数,将在when方法后面立即运行。
利用这个特点,我们可以写一个具有缓存效果的异步操作函数。也就是说,第一次调用这个函数的时候,将执行异步操作,后面再调用这个函数,将会返回缓存的结果。
代码如下:
function maybeAsync( num ) { var dfd = $.Deferred(); if ( num === 1 ) { setTimeout(function() { dfd.resolve( num ); }, 100); return dfd.promise(); } return num;}$.when(maybeAsync(1)).then(function (resp){ $('#target').append(' ' + resp + ' ');}); $.when(maybeAsync(0)).then(function (resp){ $('#target').append( ' ' + resp + ' ');});
上面代码表示,如果maybeAsync函数的参数为1,则执行异步操作,否则立即返回缓存的结果。
实例
wait方法
我们可以用deferred对象写一个wait方法,表示等待多少毫秒后再执行。
代码如下:
$.wait = function(time) { return $.Deferred(function(dfd) { setTimeout(dfd.resolve, time); }); }
使用方法如下:
代码如下:
$.wait(5000).then(function() { alert("Hello from the future!"); });
改写setTimeout方法
在上面的wait方法的基础上,还可以改写setTimeout方法,让其返回一个deferred对象。
代码如下:
function doSomethingLater(fn, time) { var dfd = $.Deferred(); setTimeout(function() { dfd.resolve(fn()); }, time || 0); return dfd.promise(); } var promise = doSomethingLater(function (){ console.log( '已经延迟执行' ); }, 100);
自定义操作使用deferred接口
我们可以利用deferred接口,使得任意操作都可以用done()和fail()指定回调函数。
代码如下:
Twitter = { search:function(query) { var dfr = $.Deferred(); $.ajax({ url:"http://search.twitter.com/search.json", data:{q:query}, dataType:'jsonp', success:dfr.resolve }); return dfr.promise(); } }
使用方法如下:
代码如下:
Twitter.search('intridea').then(function(data) { alert(data.results[0].text);});
deferred对象的另一个优势是可以附加多个回调函数。
代码如下:
function doSomething(arg) { var dfr = $.Deferred(); setTimeout(function() { dfr.reject("Sorry, something went wrong."); }); return dfr; } doSomething("uh oh").done(function() { alert("Won't happen, we're erroring here!"); }).fail(function(message) { alert(message) });
以上就是jQuery之Deferred对象详解的内容,更多相关内容请关注PHP中文网(www.php.cn)!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Detaillierte Erläuterung der jQuery-Referenzmethode: Kurzanleitung jQuery ist eine beliebte JavaScript-Bibliothek, die häufig in der Website-Entwicklung verwendet wird. Sie vereinfacht die JavaScript-Programmierung und bietet Entwicklern umfangreiche Funktionen und Features. In diesem Artikel wird die Referenzmethode von jQuery ausführlich vorgestellt und spezifische Codebeispiele bereitgestellt, um den Lesern einen schnellen Einstieg zu erleichtern. Einführung in jQuery Zuerst müssen wir die jQuery-Bibliothek in die HTML-Datei einführen. Es kann über einen CDN-Link eingeführt oder heruntergeladen werden

Wie verwende ich die PUT-Anfragemethode in jQuery? In jQuery ähnelt die Methode zum Senden einer PUT-Anfrage dem Senden anderer Arten von Anfragen, Sie müssen jedoch auf einige Details und Parametereinstellungen achten. PUT-Anfragen werden normalerweise zum Aktualisieren von Ressourcen verwendet, beispielsweise zum Aktualisieren von Daten in einer Datenbank oder zum Aktualisieren von Dateien auf dem Server. Das Folgende ist ein spezifisches Codebeispiel, das die PUT-Anforderungsmethode in jQuery verwendet. Stellen Sie zunächst sicher, dass Sie die jQuery-Bibliotheksdatei einschließen. Anschließend können Sie eine PUT-Anfrage senden über: $.ajax({u

Wie entferne ich das Höhenattribut eines Elements mit jQuery? Bei der Front-End-Entwicklung müssen wir häufig die Höhenattribute von Elementen manipulieren. Manchmal müssen wir möglicherweise die Höhe eines Elements dynamisch ändern, und manchmal müssen wir das Höhenattribut eines Elements entfernen. In diesem Artikel wird erläutert, wie Sie mit jQuery das Höhenattribut eines Elements entfernen, und es werden spezifische Codebeispiele bereitgestellt. Bevor wir jQuery zum Betreiben des Höhenattributs verwenden, müssen wir zunächst das Höhenattribut in CSS verstehen. Das Höhenattribut wird verwendet, um die Höhe eines Elements festzulegen

Titel: jQuery-Tipps: Ändern Sie schnell den Text aller Tags auf der Seite. In der Webentwicklung müssen wir häufig Elemente auf der Seite ändern und bedienen. Wenn Sie jQuery verwenden, müssen Sie manchmal den Textinhalt aller a-Tags auf der Seite gleichzeitig ändern, was Zeit und Energie sparen kann. Im Folgenden wird erläutert, wie Sie mit jQuery den Text aller Tags auf der Seite schnell ändern können, und es werden spezifische Codebeispiele angegeben. Zuerst müssen wir die jQuery-Bibliotheksdatei einführen und sicherstellen, dass der folgende Code in die Seite eingefügt wird: <

Titel: Verwenden Sie jQuery, um den Textinhalt aller Tags zu ändern. jQuery ist eine beliebte JavaScript-Bibliothek, die häufig zur Verarbeitung von DOM-Operationen verwendet wird. Bei der Webentwicklung müssen wir häufig den Textinhalt des Link-Tags (eines Tags) auf der Seite ändern. In diesem Artikel wird erläutert, wie Sie mit jQuery dieses Ziel erreichen, und es werden spezifische Codebeispiele bereitgestellt. Zuerst müssen wir die jQuery-Bibliothek in die Seite einführen. Fügen Sie den folgenden Code in die HTML-Datei ein:

jQuery ist eine schnelle, kleine und funktionsreiche JavaScript-Bibliothek, die häufig in der Front-End-Entwicklung verwendet wird. Seit seiner Veröffentlichung im Jahr 2006 ist jQuery für viele Entwickler zu einem der bevorzugten Tools geworden, hat in der Praxis jedoch auch einige Vor- und Nachteile. In diesem Artikel werden die Vor- und Nachteile von jQuery eingehend analysiert und anhand spezifischer Codebeispiele veranschaulicht. Vorteile: 1. Prägnante Syntax Das Syntaxdesign von jQuery ist prägnant und klar, was die Lesbarkeit und Schreibeffizienz des Codes erheblich verbessern kann. Zum Beispiel,

jQuery ist eine beliebte JavaScript-Bibliothek, die häufig zur DOM-Manipulation und Ereignisbehandlung in Webseiten verwendet wird. In jQuery wird die Methode eq() verwendet, um Elemente an einer bestimmten Indexposition auszuwählen. Die spezifischen Verwendungs- und Anwendungsszenarien sind wie folgt. In jQuery wählt die Methode eq() das Element an einer angegebenen Indexposition aus. Indexpositionen beginnen bei 0 zu zählen, d. h. der Index des ersten Elements ist 0, der Index des zweiten Elements ist 1 und so weiter. Die Syntax der eq()-Methode lautet wie folgt: $("s

Wie kann man feststellen, ob ein jQuery-Element ein bestimmtes Attribut hat? Wenn Sie jQuery zum Betreiben von DOM-Elementen verwenden, stoßen Sie häufig auf Situationen, in denen Sie feststellen müssen, ob ein Element ein bestimmtes Attribut hat. In diesem Fall können wir diese Funktion einfach mit Hilfe der von jQuery bereitgestellten Methoden implementieren. Im Folgenden werden zwei häufig verwendete Methoden vorgestellt, um festzustellen, ob ein jQuery-Element über bestimmte Attribute verfügt, und um spezifische Codebeispiele anzuhängen. Methode 1: Verwenden Sie die Methode attr() und den Operator typeof //, um zu bestimmen, ob das Element ein bestimmtes Attribut hat
