中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

jQuery通過deferred對象管理ajax異步
來源:易賢網 閱讀:941 次 日期:2016-06-25 14:40:21
溫馨提示:易賢網小編為您整理了“jQuery通過deferred對象管理ajax異步”,方便廣大網友查閱!

這篇文章主要介紹了jQuery通過deferred對象管理ajax異步的相關資料,需要的朋友可以參考下

今天跟大家分享一個jquery中的對象-deferred。其實從jQuery 1.5.0版本開始引入的一個新功能----deferred對象。不過可能在實際開發過程中用到的并不多,所以沒有太在意。

什么是deferred對象?

開發網站的過程中,我們經常遇到某些耗時很長的javascript操作。其中,既有異步的操作(比如ajax讀取服務器數據),也有同步的操作(比如遍歷一個大型數組),它們都不是立即能得到結果的。

通常的做法是,為它們指定回調函數(callback)。即事先規定,一旦它們運行結束,應該調用哪些函數。

但是,在回調函數方面,jQuery的功能非常弱。為了改變這一點,jQuery開發團隊就設計了deferred對象。

簡單說,deferred對象就是jQuery的回調函數解決方案。在英語中,defer的意思是"延遲",所以deferred對象的含義就是"延遲"到未來某個點再執行。

這里先不說deferred的概念,我們先看一個例子。

還記得初學的時候,遇到一個實例,先是要ajax請求一個接口(a.json),從返回的數據中獲得一個id1值。然后再請求一個接口(b.json)獲得id2,最后需要對這兩個id值同時進行操作。

錯誤解法

那個時候初學,首先想到的方案(現在想想,很傻很天真...)

var id1, id2;

$.ajax({

url: 'a.js',

dataType: 'json',

type: 'get',

success: function(d){

id1 = d.item.id;

}

});

$.ajax({

url: 'b.js',

dataType: 'json',

type: 'get',

success: function(d){

id2 = d.item.id;

}

})

alert('id1='+id1+','+ 'id2='+ id2);

因為那個時候,還沒有理解異步的概念,所以以為,第二次ajax的時候id已經有值了,但是運行之后才發現,變量id其實根本沒被賦值。想要測試上面代碼,點這里也就是這一刻,我真正明白了:ajax是異步的?。。 ?/P>

傻瓜式解法

發現上面那個方法不能用之后,分析了一下,彈出undefined是因為彈出之前id還沒有被賦值,那我保證在彈出之前給id賦值不就解決了嗎?好的,于是我想到了下面這個方法:

var id1;

$.ajax({

url: '/test/json/a.js',

dataType: 'json',

type: 'get',

success: function(d){

id1 = d.item.id;

$.ajax({

url: '/test/json/b.js',

dataType: 'json',

type: 'get',

success: function(f){

id2 = f.item.id;

alert('id1='+id1+','+ 'id2='+ id2);

}

});

}

})

邏輯雖然正確了,但總覺得怪怪的,如果這里需要嵌套3層呢?4層呢?。。。ajax里面嵌套ajax,如果數據很多,訪問速度慢,嵌套更多層,會導致性能下降、影響用戶體驗、代碼不好維護等等問題。所以一般不推薦這種方法??傊?,這種寫法讓我難以接受。

所以思來想去,覺得不妥。。。然后那個時候就在一個前端群里,詢問各種大牛,直到一個大牛告訴我讓我百度一下deferred,后來認真學習了下,覺得不錯。

使用deferred對象

deferred對象簡介

deferred是jquery中的擴展的一個對象(1.5.0以上的版本支持deferred)。defer的意思是"延遲",所以deferred對象的含義就是"延遲"到未來某個點再執行。

簡單說,deferred對象就是jQuery的回調函數解決方案。

再簡單說,deferred對象用來管理異步操作,而ajax就是一種異步操作。

deferred基本語法

deferred讓ajax支持新的寫法,代碼如下:

$.ajax({

url: '/test/json/a.js',

dataType: 'json',

type: 'get'

})

.done(function() {

alert("成功啦!");

})

.fail(function() {

alert("失敗了...");

})

這個大家應該都知道?,F在在編輯器敲入ajax,然后回車,提示的ajax語法結構就是這樣鏈式的寫法。

done函數就是ajax請求成功的回到函數;

fail函數就是ajax請求失敗的回調函數。

使用deferred的解決方法

var ajax1 = $.ajax({

url: '/test/json/a.js',

dataType: 'json',

type: 'get'

});

var ajax2 = $.ajax({

url: '/test/json/b.js',

dataType: 'json',

type: 'get',

});

$.when(ajax1,ajax2).done(function(d1,d2){

var id1 = d1[0].item.id;

var id2 = d2[0].item.id;

alert('id1='+id1+', '+ 'id2='+ id2);

}).fail(function(){

alert('error');

});

值得一提的是,上面代碼中done函數的參數,對應的是前面每一個ajax請求返回的數據上面的代碼中,用到了deferred對象的when方法。

它的描述是:

提供一種方法來執行一個或多個對象的回調函數。

這里的ajax1和ajax2就是deferred對象,done和fail就是回調函數。上面代碼的意思是:

只有當兩個ajax請求都成功返回數據時,執行done函數;只要有一個請求不成功,就執行fail函數。

另外值得一提的是:$.when方法的參數,只支持deferred對象,而ajax返回的就是deferred對象。`

這就已經實現了上面的需求了。請求兩個接口,獲得兩個數據,都成功時,對這兩個數據同時進行處理。而且這種鏈式寫法,讓讀者一目了然,而且便于維護擴展。

deferred方法匯總

提到的方法

$.Deferred():生成一個deferred對象。

$.when() 為多個操作指定回調函數。

deferred.done():指定操作成功后的回調函數

deferred.fail():指定操作失敗后的回調函數

未提到的方法

•deferred.resolve()方法和deferred.reject()方法

deferred對象執行回調函數之前會有一個執行狀態的存在,執行狀態一共有三種———未完成、已完成和已失敗。

未完成狀態,則會繼續等待,或者執行progress()指定的回調函數。

已完成狀態,則會執行done()方法指定的回調函數。

已失敗狀態,則會執行fail()方法指定的回調函數。

所以這里的deferred.resolve()方法就是手動將deferred對象的狀態改為已完成,繼而執行done方法; deferred.reject()方法就是手動將狀態改為已失敗,繼而執行fail方法。

下面來看一個例子:

var defer = $.Deferred(); // 新建一個Deferred對象

    var wait = function(defer){

    var tasks = function(){

defer.resolve(); // 改變Deferred對象為已完成狀態

     alert("執行完畢!");

    };

    setTimeout(tasks,5000);

    return defer;

  };

  $.when(wait(defer))

  .done(function(){

   alert("succeed");

   })

  .fail(function(){

   alert("failed");

  });

結果:等待5秒鐘,先彈出“succeed”,在彈出“執行完畢!”。

分析一下代碼執行過程:

$.when()里面的參數是wait函數,也就是一個deferred對象,所以可以繼續執行setTimeout函數,等待5s,執行tasks函數,然后手動改變了狀態為“已完成”,所以執行done方法,彈出“succeed”,然后彈出“執行完畢!”。

deferred.then():有時為了省事,可以把done()和fail()合在一起寫,這就是then()方法。

function successFun(){

alert("yes");

}

function failFun(){

alert('fail');

}

$.when($.ajax({

url: '/test/json/a.js',

dataType:'json',

type: 'get'

}))

.then(successFun, failFun);

當then方法只有一個參數時,相當于done方法。當有兩個參數時,第一個相當于done方法,第二個相當于fail方法。

總結:

deferred對象通過對一個ajax請求的各種回調函數的控制,讓jquery寫ajax變的簡單、容易維護、容易擴展。

以上所述是小編給大家介紹的jQuery通過deferred對象管理ajax異步的相關知識,希望對大家有所幫助

更多信息請查看網絡編程
易賢網手機網站地址:jQuery通過deferred對象管理ajax異步
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!

2026上岸·考公考編培訓報班

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
云南網警備案專用圖標
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網
云南網警報警專用圖標
中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
欧美jizzhd精品欧美巨大免费| 亚洲人成在线观看| 亚洲综合色噜噜狠狠| 亚洲综合视频一区| 久久久噜噜噜久久久| 欧美精品性视频| 国产欧美一区二区三区久久| 亚洲国产你懂的| 欧美怡红院视频| 欧美日本免费一区二区三区| 欧美jizz19性欧美| 嫩模写真一区二区三区三州| 国产精品视频网址| 亚洲国产精品高清久久久| 亚洲欧美国产高清| 欧美精品999| 国产日韩欧美二区| 亚洲视频高清| 国产免费观看久久黄| 国产亚洲精品一区二区| 亚洲精品在线观| 久久国产主播精品| 国产伦精品一区| 亚洲视频中文| 欧美日韩一区二区免费在线观看| 国产午夜精品福利| 亚洲一区二区三区免费观看| 欧美伦理视频网站| 91久久综合| 免费日韩av电影| 精品福利av| 久久久久一区| 精品成人一区二区| 久久免费99精品久久久久久| 好看的日韩视频| 久久在线观看视频| 亚洲精品乱码久久久久久日本蜜臀| 老司机久久99久久精品播放免费| 在线看片成人| 欧美日本一区二区三区| 一个色综合av| 国产欧美日韩另类一区| 欧美中文字幕不卡| 亚洲高清精品中出| 欧美日韩亚洲一区二| 亚洲欧美日韩在线播放| 韩国自拍一区| 欧美日韩国产成人精品| 亚洲男人影院| 在线精品亚洲| 国产精品美女久久久浪潮软件| 欧美在线你懂的| 亚洲国产一二三| 国产精品久久久久久久午夜 | 欧美一区二区高清在线观看| 国产欧美一区二区在线观看| 欧美在线观看一区二区| 亚洲国产精品v| 亚洲国产精品一区二区www| 欧美在线免费观看视频| 今天的高清视频免费播放成人| 久久久久国内| 夜夜嗨av一区二区三区免费区| 国产精品日韩欧美大师| 久久亚洲美女| 亚洲一区三区视频在线观看| 国产一区深夜福利| 欧美亚州在线观看| 巨胸喷奶水www久久久免费动漫| 日韩一级免费| 136国产福利精品导航网址应用| 欧美人与禽猛交乱配| 欧美在线观看视频一区二区| 亚洲激情亚洲| 国内精品嫩模av私拍在线观看| 亚洲国产精品va在线观看黑人| 亚洲一区二区三区三| 亚洲国产免费看| 黄色亚洲免费| 国产精品美女| 欧美片第1页综合| 久久尤物电影视频在线观看| 亚洲女ⅴideoshd黑人| 亚洲人成绝费网站色www| 国产亚洲成年网址在线观看| 欧美日韩精品| 欧美精品在线观看播放| 久久久久久久高潮| 欧美一级日韩一级| 亚洲永久免费视频| 99亚洲一区二区| 亚洲日本成人网| 亚洲国产精品精华液2区45| 国产一区二区三区观看| 国产精品免费视频xxxx| 欧美黑人多人双交| 欧美成人午夜激情视频| 久久青青草综合| 久久资源在线| 老司机精品福利视频| 男同欧美伦乱| 欧美国产日本韩| 亚洲国产一区二区精品专区| 国产欧美视频一区二区三区| 国产精品久久久久久久久借妻| 欧美色区777第一页| 欧美日韩免费高清一区色橹橹| 欧美激情影院| 欧美日韩另类视频| 欧美日韩一区二区三区高清| 欧美日韩国产页| 欧美四级在线观看| 国产精品无码永久免费888| 国产精品三级视频| 国产精品亚洲аv天堂网| 国产欧美一二三区| 在线观看av不卡| 亚洲精品国产视频| 在线亚洲免费| 欧美一区二区三区日韩视频| 久久久久九九视频| 嫩草国产精品入口| 国产精品xxx在线观看www| 国产午夜久久久久| 亚洲欧洲日本国产| 亚洲一区二区在| 久久久之久亚州精品露出| 欧美国产精品日韩| 国产精品久久久久久久午夜片 | 亚洲性人人天天夜夜摸| 亚洲一区二区成人| 久久久久欧美| 欧美视频亚洲视频| 狠狠干综合网| 中文精品99久久国产香蕉| 香蕉亚洲视频| 欧美精品免费看| 国产精品久久久久久久久动漫| 欧美午夜激情视频| 在线观看一区| 亚洲欧美日韩国产中文在线| 狂野欧美激情性xxxx| 欧美三级欧美一级| 尤物九九久久国产精品的特点| 一区二区三区高清| 牛牛影视久久网| 国产夜色精品一区二区av| 99在线精品视频| 久久一区免费| 国产午夜精品视频免费不卡69堂| 国产精品视频一二| 一区二区三区在线看| 亚洲综合国产精品| 欧美日韩你懂的| 亚洲欧洲午夜| 久久中文字幕一区| 好吊妞这里只有精品| 欧美一区二区三区在线播放| 欧美精品国产一区二区| 国产婷婷成人久久av免费高清 | 欧美成人一区二区三区片免费| 国产精品久久久| 亚洲精品免费在线观看| 久久se精品一区二区| 欧美午夜www高清视频| 亚洲国产精品一区二区第一页| 久久经典综合| 狠狠色狠色综合曰曰| 久久国产精品久久久| 国产美女一区二区| 亚洲欧美另类在线| 欧美欧美午夜aⅴ在线观看| 在线观看视频免费一区二区三区| 久久se精品一区二区| 日韩一级片网址| 欧美高清一区| 日韩一区二区精品葵司在线| 欧美精品在线视频| 日韩午夜在线电影| 欧美日韩日本网| 亚洲第一色在线| 欧美顶级少妇做爰| 99在线|亚洲一区二区| 欧美日韩中文字幕| 亚洲视频在线看| 国产日韩亚洲欧美综合| 久久久久青草大香线综合精品| 亚洲第一色在线| 欧美视频二区| 久久精品观看| 亚洲欧洲一区二区在线观看| 欧美精品在线观看一区二区| 宅男噜噜噜66一区二区| 国产伦精品一区二区三区高清版| 欧美中文字幕久久| 亚洲大胆美女视频| 国产精品盗摄久久久| 久久激情久久| 99精品视频一区二区三区| 国产精品videossex久久发布|