Maison >interface Web >js tutoriel >Explication détaillée de l'objet différé de jQuery

Explication détaillée de l'objet différé de jQuery

PHP中文网
PHP中文网original
2017-03-30 15:12:321355parcourir

différéObject est l'interface jQuery des promesses implémentation. Il s'agit d'une interface générale pour les opérations asynchrones et peut être considérée comme une tâche en attente d'être terminée via certaines interfaces. En fait, elle joue le rôle de proxy dans des objets. certaines caractéristiques unifiées. Des exemples typiques sont les opérations Ajax, les animations de page Web , les web Workers, etc. Toutes les opérations Ajax

fonctions de jQuery, renvoient par défaut un objet différé

<.>Que sont les promesses ? Cela prend beaucoup de temps et d'autres opérations doivent être mises en file d'attente. Afin d'éviter que l'ensemble du programme ne réponde, la solution habituelle est d'écrire ces opérations sous la forme ". fonction de rappel

" (rappel) comme ceci. Bien qu'elle puisse résoudre le problème, elle présente quelques inconvénients importants :

1. Les fonctions de rappel sont souvent écrites sous la forme de paramètres de fonction

, ce qui rend l'entrée et la sortie de la fonction très confuses et l'ensemble du programme ne peut pas être lu. Mauvaises performances

2. S'il y a plusieurs opérations, la fonction de rappel doit être spécifiée. être réécrit. 3. L'ensemble du processus d'exécution du programme est perturbé, le débogage et le débogageLa difficulté augmente en conséquence

Des promesses ont été proposées pour résoudre ces problèmes. Remplacez les fonctions de rappel et devenez une solution pour les opérations asynchrones.Son idée principale est de permettre aux opérations asynchrones de renvoyer un objet et d'autres opérations sont effectuées sur cet objet.Par exemple, supposons que l'opération ajax renvoie un objet Promise. comme suit :

Ensuite, l'objet Promise a une méthode then. qui peut être utilisée pour spécifier une fonction de rappel. Une fois l'opération asynchrone terminée, la fonction de rappel spécifiée est appelée. :

peut combiner les deux ci-dessus. Les extraits de code sont combinés afin que le flux du programme soit vu plus clairement >

Le code est le suivant :

Après la version 1.7, les opérations Ajax renvoient directement les objets Promise, ce qui signifie que la fonction de rappel peut être spécifiée à l'aide de la méthode then Le code est le suivant :

var promise = get(&#39;http://www.example.com&#39;);

<.>Méthode objet différé

La méthode $.deferred()
promise.then(function (content) {
  console.log(content)
})


est utilisée pour générer un objet différé.

Le code est le suivant :

get(&#39;http://www.example.com&#39;).then(function (content) {
  console.log(content)
})


done() et fail()

$.ajax({
    url:"/echo/json/",
    success: function(response)
    {
       console.info(response.name);
    }
});
Les deux méthodes sont utilisées Fonction de rappel de liaison. done() spécifie la fonction de rappel après la réussite de l'opération asynchrone, et fail() spécifie la fonction de rappel après l'échec.


Le code est le suivant :

$.ajax({
    url: "/echo/json/",
}).then(function (response) {
    console.info(response.name);
});
Ils renvoient l'objet différé d'origine, vous pouvez donc utiliser l'écriture en chaîne, puis lier d'autres méthodes (y compris done et fail) à l'intérieur ).

resolve() et rejet()

sont utilisés pour changer le état

de l'objet différé. solve() change le statut en réussite de l'opération asynchrone et rejet() change le statut en échec de l'opération.


Le code est le suivant :

var deferred = $.deferred();

Une fois solve() appelée, les fonctions de rappel spécifiées par les méthodes done() et then() seront exécuté en séquence ; une fois le rejet appelé (), les fonctions de rappel spécifiées par les méthodes fail() et then() seront exécutées en séquence.
méthode d'état


Cette méthode est utilisée pour renvoyer l'état actuel de l'objet différé.

Le code est le suivant :
var deferred = $.Deferred();
deferred.done(function(value) {
   alert(value);
});

Cette méthode a trois valeurs de retour :

notify() et progress()
progress() est utilisé pour spécifier une fonction de rappel, qui sera exécutée lorsque la méthode notify() est appelée. Son but est de fournir une interface pour que certaines opérations puissent être effectuées lors de l'exécution d'opérations asynchrones, comme par exemple retourner régulièrement la progression de la

barre de progression

.

var deferred = $.Deferred();
deferred.done(function(value) {
   alert(value);
});
deferred.resolve("hello world");

Le code est le suivant :

then()

then() est également utilisé pour spécifier la fonction de rappel , qui peut accepter trois paramètres, c'est-à-dire trois fonctions de rappel. Le premier paramètre est la fonction de rappel appelée lors de la résolution, le deuxième paramètre est la fonction de rappel appelée lors du rejet et le troisième paramètre est la fonction de rappel appelée par la méthode progress().

Le code est le suivant :

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(&#39;/echo/json/&#39;, {json:JSON.stringify({&#39;error&#39;: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 = $(&#39;p.alert&#39;).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){  
 $(&#39;#target&#39;).append(&#39;
&#39; + resp + &#39;
&#39;);});
$.when(maybeAsync(0)).then(function (resp){  
$(&#39;#target&#39;).append( &#39;
&#39; + resp + &#39;
&#39;);});

上面代码表示,如果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( &#39;已经延迟执行&#39; );
}, 100);

自定义操作使用deferred接口

我们可以利用deferred接口,使得任意操作都可以用done()和fail()指定回调函数。

代码如下:

Twitter = {
  search:function(query) {
    var dfr = $.Deferred();
    $.ajax({
     url:"http://search.twitter.com/search.json",
     data:{q:query},
     dataType:&#39;jsonp&#39;,
     success:dfr.resolve
    });
    return dfr.promise();
  }
}

使用方法如下:

代码如下:

Twitter.search(&#39;intridea&#39;).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&#39;t happen, we&#39;re erroring here!");
}).fail(function(message) {
  alert(message)
});

 以上就是jQuery之Deferred对象详解的内容,更多相关内容请关注PHP中文网(www.php.cn)!


Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn