成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

熟練使用使用jQuery Promise (Deferred)

zhjx922 / 2310人閱讀

摘要:情景再現(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

相關(guān)文章

  • 通過 ES6 PromisejQuery Deferred 的異同學(xué)習(xí) Promise

    摘要:和和都有和,但是略有不同。實際上返回的是一個對象。和添加的回調(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...

    Yujiaao 評論0 收藏0
  • jQuery deffered和promise對象方法

    摘要:三和對象方法對象其實就是對象的特例,因為對象不能更改異步狀態(tài),而對象可以。方法依次接受三個回調(diào),分別為對象后觸發(fā)的回調(diào),返回一個對象。注意,必須傳入函數(shù),而該函數(shù)只有返回一個對象,才能夠讓異步事件按照預(yù)期順序來執(zhí)行。對象的方法對象和對象 一、前言 為了讓前端們從回調(diào)的地獄中回到天堂,jQuery也引入了Promise的概念。Promise是一種令代碼異步行為更加優(yōu)雅的抽象,有了它,我...

    Render 評論0 收藏0
  • jQuery源碼解析Deferred異步對象

    摘要:回調(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對象,直...

    Coding01 評論0 收藏0
  • Promise介紹--DeferredjQuery

    摘要:我們稱為回調(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沒...

    Darkgel 評論0 收藏0
  • jQuery中的Deferredpromise 的區(qū)別

    摘要:使用的好處有以下幾點你可以多次調(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ù)時你需要使用一...

    rickchen 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<