本篇內(nèi)容主要講解“jQuery.when()怎么使用”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“jQuery.when()怎么使用”吧!
創(chuàng)新互聯(lián)主要從事網(wǎng)站制作、成都網(wǎng)站設(shè)計、網(wǎng)頁設(shè)計、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)伍家崗,十多年網(wǎng)站建設(shè)經(jīng)驗,價格優(yōu)惠、服務(wù)專業(yè),歡迎來電咨詢建站服務(wù):028-86922220
在案例中有多個延遲對象傳遞給jQuery.when ,該方法返回一個新的“宿主”延遲對象,跟蹤所有已通過Deferreds聚集狀態(tài)。 當(dāng)所有的延遲對象被受理(resolve)時,該方法才會受理它的 master 延遲對象。當(dāng)其中有一個延遲對象被拒絕(rejected)時,該方法就會拒絕它的 master 延遲對象。如果 master 延遲對象被受理(resolved),那么會傳入所有延遲對象的受理(resolved)值,這些延遲對象指的就是傳給 jQuery.when 的參數(shù)。例如,當(dāng)延遲對象是 jQuery.ajax() 請求,那么傳入的受理(resolved)參數(shù)就是請求用的 jqXHR 對象,傳入順序就是它們在參數(shù)列表中的順序。
在多延遲情況下,如果延遲一被拒絕,jQuery.when觸發(fā)立即調(diào)用 master 延遲對象的 failCallbacks。請注意,在上述情況中,有一些延遲對象依然是不能被受理(unresolved)的。那么,在這種情況下,如果需要執(zhí)行一些額外的處理,例如,取消所有未完成的 ajax 請求,你可以在閉包中進(jìn)行保持 jqXHR 對象的引用,并且在 failCallback 中檢查或取消它們。
例子:
Example: 執(zhí)行Ajax請求后兩個函數(shù)是成功的。(見jQuery.ajax()對于一個成功的和錯誤的案件為AJAX請求的完整描述文檔)。
$.when($.ajax("/page1.php"), $.ajax("/page2.php")).done(function(a1, a2){
/* a1 and a2 are arguments resolved for the
page1 and page2 ajax requests, respectively */
var jqXHR = a1[2]; /* arguments are [ "success", statusText, jqXHR ] */
if ( /Whip It/.test(jqXHR.responseText) ) {
alert("First page has 'Whip It' somewhere.");
}
});
Example: 執(zhí)行函數(shù)myFunc當(dāng)兩個Ajax請求是成功的,如果任一或myFailure有一個錯誤。
$.when($.ajax("/page1.php"), $.ajax("/page2.php"))
.then(myFunc, myFailure);
到此,相信大家對“jQuery.when()怎么使用”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!