deferred物件是jQuery對Promises介面的實現。將那些非同步操作包裝成具有某些統一特性的對象,典型例子就是Ajax操作、網頁動畫、web worker等等。
,預設回傳的就是一個deferred物件。耗時很長,其他操作就必需排隊等待。做雖然可以解決問題,但是有一些顯著缺點:1.回調函數往往寫成函數參數
的形式,導致函數的輸入和輸出非常混亂,整個程式的可閱讀性差;2.回呼函數往往只能指定一個,如果有多個操作,就需要改寫回調函數。 >的難度都相應增加。一個對象,其他操作都是針對這個對象來完成。方法,可以用來指定回呼函數。段程式碼合併起來,這樣程式的流程看得更清楚。 > 程式碼如下:
1.7版之後,Ajax操作直接傳回Promise對象,這表示可以用then方法指定回呼函數。程式碼如下:
deferred物件的方法
作用是產生一個deferred物件。
var promise = get('http://www.example.com');
promise.then(function (content) { console.log(content) })
這兩個方法都用來綁定回調函數。 done()指定非同步操作成功後的回呼函數,fail()指定失敗後的回呼函數。
get('http://www.example.com').then(function (content) { console.log(content) })它們回傳的是原有的deferred對象,因此可以採用鍊式寫法,在後面再連結別的方法(包括done和fail在內)。
$.ajax({ url:"/echo/json/", success: function(response) { console.info(response.name); } });這兩個方法用來改變deferred物件的
狀態
。 resolve()將狀態改為非同步操作成功,reject()改為操作失敗。
$.ajax({ url: "/echo/json/", }).then(function (response) { console.info(response.name); });
一旦呼叫resolve(),就會依序執行done()和then()方法指定的回呼函數;一旦呼叫reject (),就會依序執行fail()和then()方法指定的回呼函數。
state方法
此方法用來傳回deferred物件目前的狀態。
程式碼如下:
var deferred = $.deferred();
此方法的回傳值有三個:
notify() 和progress( )
progress()用來指定一個回呼函數,當呼叫notify()方法時,該回調函數將會執行。它的用意是提供一個接口,使得在非同步操作執行過程中,可以執行某些操作,例如定期返回
進度條var deferred = $.Deferred(); deferred.done(function(value) { alert(value); });的進度。
程式碼如下:
then()
then()的作用也是指定回調函數,它可以接受三個參數,也就是三個回呼函數。第一個參數是resolve時呼叫的回呼函數,第二個參數是reject時呼叫的回呼函數,第三個參數是progress()方法呼叫的回呼函數。
var deferred = $.Deferred(); deferred.done(function(value) { alert(value); }); deferred.resolve("hello world");
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)!

实现方法:1、用“$("img").delay(毫秒数).fadeOut()”语句,delay()设置延迟秒数;2、用“setTimeout(function(){ $("img").hide(); },毫秒值);”语句,通过定时器来延迟。

区别:1、axios是一个异步请求框架,用于封装底层的XMLHttpRequest,而jquery是一个JavaScript库,只是顺便封装了dom操作;2、axios是基于承诺对象的,可以用承诺对象中的方法,而jquery不基于承诺对象。

修改方法:1、用css()设置新样式,语法“$(元素).css("min-height","新值")”;2、用attr(),通过设置style属性来添加新样式,语法“$(元素).attr("style","min-height:新值")”。

增加元素的方法:1、用append(),语法“$("body").append(新元素)”,可向body内部的末尾处增加元素;2、用prepend(),语法“$("body").prepend(新元素)”,可向body内部的开始处增加元素。

删除方法:1、用empty(),语法“$("div").empty();”,可删除所有子节点和内容;2、用children()和remove(),语法“$("div").children().remove();”,只删除子元素,不删除内容。

在jquery中,apply()方法用于改变this指向,使用另一个对象替换当前对象,是应用某一对象的一个方法,语法为“apply(thisobj,[argarray])”;参数argarray表示的是以数组的形式进行传递。

on()方法有4个参数:1、第一个参数不可省略,规定要从被选元素添加的一个或多个事件或命名空间;2、第二个参数可省略,规定元素的事件处理程序;3、第三个参数可省略,规定传递到函数的额外数据;4、第四个参数可省略,规定当事件发生时运行的函数。

去掉方法:1、用“$(selector).removeAttr("readonly")”语句删除readonly属性;2、用“$(selector).attr("readonly",false)”将readonly属性的值设置为false。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

Dreamweaver CS6
視覺化網頁開發工具

禪工作室 13.0.1
強大的PHP整合開發環境

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境