摘要:情景再現(xiàn)以前用寫后端程序時,遇到這個概念,這個東西好呀不用謝一層一層回調(diào),直接用類似于的連綴方式。后來遇到這個庫,它就是庫中很有名的。我希望可以把用在前端的請求上,但是我不想又引入。后來發(fā)現(xiàn),本身就具有類似于的東西。
1 情景再現(xiàn)
以前用nodejs寫后端程序時,遇到Promise這個概念,這個東西好呀!不用謝一層一層回調(diào),直接用類似于jQuery的連綴方式。后來遇到bluebird這個庫,它就是Promise庫中很有名的。我希望可以把Promise用在前端的ajax請求上,但是我不想又引入bluebird。后來發(fā)現(xiàn),jquery本身就具有類似于Promise的東西。于是我就jquery的Promise寫一些異步請求。
2 不堪回首看看一看我以前寫異步請求的方式
// 函數(shù)定義 function sendRequest(req,successCallback,errorCallback){ $.ajax({ ... ... success:function(res){ successCallback(res); }, error:function(res){ errorCallback(res); } }); } // 函數(shù)調(diào)用,這個函數(shù)的匿名函數(shù)寫的時候很容易出錯,而且有時候難以理解 sendRequest(req,function(res){ //請求成功 ... },function(res){ //請求失敗 ... });3 面朝大海
下面是我希望的異步調(diào)用方式
sendRequest(req) .done(function(res){ //請求成功 ... }) .fail(function(req){ //請求失敗 ... });4 廢話少說,放‘碼’過來
talk is cheap, show me the code
// 最底層的發(fā)送異步請求,做成Promise的形式 App.addMethod("_sendRequest",function(path,method,payload){ var dfd = $.Deferred(); $.ajax({ url:path, type:method || "get", headers:{ sessionId:session.id || "" }, data:JSON.stringify(payload), dataType:"json", contentType : "application/json; charset=UTF-8", success:function(data){ dfd.resolve(data); }, error:function(data){ dfd.reject(data); } }); return dfd.promise(); }); //根據(jù)callId查詢錄音文件,不僅僅是異步請求可以做成Promise形式,任何函數(shù)都可以做成Promise形式 App.addMethod("_getRecordingsByCallId",function(callId){ var dfd = $.Deferred(), path = "/api/tenantcalls/"+callId+"/recordings"; App._sendRequest(path) .done(function(res){dfd.resolve(res);}) .fail(function(res){dfd.reject(res);}); return dfd.promise(); }); // 獲取錄音 App.addMethod("getCallDetailRecordings",function(callId){ App._getRecordingsByCallId(callId) .done(function(res){ // 獲取結(jié)果后渲染數(shù)據(jù) App.renderRecording(res); }) .fail(function(res){ App.error(res); }); });5 注意事項
jQuery的Promise主要是用了jQquery的$.Derferred()方法,一些老版本的jquery并不支持此方法。
jQuery版本必須大于等于1.5,推薦使用1.11.3
6 參考文獻jquery官方api文檔
jquery維基百科文檔
7 最后以上文章僅供參考,不包完全正確。歡迎評論,3q。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/91074.html
摘要:和和都有和,但是略有不同。實際上返回的是一個對象。和添加的回調(diào),添加的回調(diào)。所以在調(diào)用成功的情況下執(zhí)行添加的回調(diào),調(diào)用失敗時執(zhí)行添加的回調(diào)。,產(chǎn)生對象并,產(chǎn)生對象并,然后繼續(xù)處理,的語法糖,和的差不多但不同。 Deferred 和 Promise ES6 和 jQuery 都有 Deffered 和 Promise,但是略有不同。不過它們的作用可以簡單的用兩句話來描述 Deffere...
摘要:三和對象方法對象其實就是對象的特例,因為對象不能更改異步狀態(tài),而對象可以。方法依次接受三個回調(diào),分別為對象后觸發(fā)的回調(diào),返回一個對象。注意,必須傳入函數(shù),而該函數(shù)只有返回一個對象,才能夠讓異步事件按照預(yù)期順序來執(zhí)行。對象的方法對象和對象 一、前言 為了讓前端們從回調(diào)的地獄中回到天堂,jQuery也引入了Promise的概念。Promise是一種令代碼異步行為更加優(yōu)雅的抽象,有了它,我...
摘要:回調(diào)隊列對象,用于構(gòu)建易于操作的回調(diào)函數(shù)集合,在操作完成后進行執(zhí)行。對象對象,用于管理回調(diào)函數(shù)的多用途列表。如果傳入一個延遲對象,則返回該對象的對象,可以繼續(xù)綁定其余回調(diào),在執(zhí)行結(jié)束狀態(tài)之后也同時調(diào)用其回調(diào)函數(shù)。 在工作中我們可能會把jQuery選擇做自己項目的基礎(chǔ)庫,因為其提供了簡便的DOM選擇器以及封裝了很多實用的方法,比如$.ajax(),它使得我們不用操作xhr和xdr對象,直...
摘要:我們稱為回調(diào)對象,它內(nèi)部會維護一個數(shù)組,我們可以向其中添加若干個回調(diào)函數(shù),然后在某一條件下觸發(fā)執(zhí)行。第一次之后,再次新的回調(diào)函數(shù)時,自動執(zhí)行回調(diào)。當前面的回調(diào)函數(shù)返回時,終止后面的回調(diào)繼續(xù)執(zhí)行。 最近懶癌發(fā)作,說好的系列文章,寫了一半,一直懶得寫,今天補上一篇。 Deferred 我們在使用promise對象時,總會提到一個與它關(guān)系密切的對象——Deferred。其實Deferred沒...
摘要:使用的好處有以下幾點你可以多次調(diào)用和函數(shù),并使用不同的回調(diào)函數(shù)?;蛟S你的一個回調(diào)函數(shù)用來停止動畫,一個用來發(fā)起一個新的請求,一個用來將接受到的數(shù)據(jù)展示給用戶。即使在調(diào)用完成之后,你依然可以調(diào)用和函數(shù),并且回調(diào)函數(shù)可以立即執(zhí)行。 Deferred和Promise之間有什么區(qū)別呢? promise 一個promise就是一個由異步函數(shù)返回的對象。當你想要自己編寫一個這樣的函數(shù)時你需要使用一...
閱讀 3214·2021-11-10 11:36
閱讀 3160·2021-11-02 14:39
閱讀 1744·2021-09-26 10:11
閱讀 4986·2021-09-22 15:57
閱讀 1700·2021-09-09 11:36
閱讀 2061·2019-08-30 12:56
閱讀 3502·2019-08-30 11:17
閱讀 1709·2019-08-29 17:17