ES6 - Promise和Ajax (精華)

導(dǎo)讀:

  • Promise實(shí)際是充當(dāng)ajax獲取后臺(tái)數(shù)據(jù)后執(zhí)行回調(diào)的異步執(zhí)行順序的一個(gè)媒介,客觀來說就是避免ajax回調(diào)地獄(反復(fù)嵌套回調(diào)),不然代碼不夠直觀授药。

例子:

  • 模擬Ajax和Promise的結(jié)合使用(Promise主要用于異步執(zhí)行順序) :
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <script src="../jquery-3.3.1.min.js"></script>
</head>
<body>
    <script type="text/javascript">
    /*
        定義一個(gè)使用promise的ajax請(qǐng)求,模擬用戶登錄場(chǎng)景
    */
    const ajaxPromise = obj => {
        return new Promise((resolve, reject) => {
            $.ajax({
                type: obj.type,
                url: obj.url,
                data: obj.data,
                success: res => {
                    resolve(res);      // 請(qǐng)求成功則轉(zhuǎn)成Promise對(duì)象并判斷為resolve狀態(tài)
                },
                error: err => {
                    reject(err.status);      // 請(qǐng)求失敗則轉(zhuǎn)成Promise對(duì)象并判斷為reject狀態(tài)
                }
            })
        })
    } 

    /*
        函數(shù)1:判斷用戶登陸成功
     */
    let userLogin = () => {
        // 第一次執(zhí)行ajaxPromise
        ajaxPromise({
            type: 'get',
            url: 'test.php',
            data: { userName: 'Verin', userPwd: '123456'}
        }).then(res => {
            console.log('后臺(tái)校驗(yàn)提交的數(shù)據(jù)并返回成功信息');        // 成功則二次ajax請(qǐng)求,取用戶信息
            getUserInfo(res);
        }).catch(err => {
            console.log('用戶校驗(yàn)提交的數(shù)據(jù)失敗沟饥,無法登陸');
        })
    }

    /*
        函數(shù)2:取出對(duì)應(yīng)登錄用戶的信息
     */
    let getUserInfo = res => {
        ajaxPromise({
            type: 'get',
            url: 'test2.php',
            data: { status: 'success to finish getUserInfo!'}
        }).then(res => {
            console.log('獲取用戶信息:');
            console.log(res);
        }).catch(err => {
            console.log('獲取用戶信息失敗' + err);
        })
    }

    userLogin();
    </script>
</body>
</html>
  • 來張效果圖 :( 書主自己模擬了后臺(tái)環(huán)境默認(rèn)都是請(qǐng)求成功的哈 )


    Result

總結(jié):

  • 剛開始接觸 Promise 的伙伴可能有點(diǎn)暈頭,書主也琢磨了好一會(huì)才想明白,故寫此簡書一篇,來個(gè) Promise 流程總結(jié):
    1 .把 ajax 返回成功 / 失敗的回調(diào)封裝成一個(gè) Promise 對(duì)象(同時(shí)判斷 resolve / reject 狀態(tài))
    2 .其對(duì)象根據(jù)傳來的狀態(tài) resolve 則執(zhí)行.then( res => {} // 實(shí)際在Promise.prototype上 )來執(zhí)行ajax一層返回成功后的二層 ajax 請(qǐng)求版述,狀態(tài)為 reject 的則執(zhí)行對(duì)象的.catch( err => {} // 實(shí)際在Promise.prototype上 )梯澜,以此類推寞冯,實(shí)現(xiàn)異步請(qǐng)求的順序執(zhí)行
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末渴析,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子吮龄,更是在濱河造成了極大的恐慌俭茧,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,496評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件漓帚,死亡現(xiàn)場(chǎng)離奇詭異母债,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)尝抖,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,407評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門毡们,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人昧辽,你說我怎么就攤上這事衙熔。” “怎么了搅荞?”我有些...
    開封第一講書人閱讀 162,632評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵红氯,是天一觀的道長。 經(jīng)常有香客問我咕痛,道長痢甘,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,180評(píng)論 1 292
  • 正文 為了忘掉前任茉贡,我火速辦了婚禮塞栅,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘腔丧。我一直安慰自己构蹬,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,198評(píng)論 6 388
  • 文/花漫 我一把揭開白布悔据。 她就那樣靜靜地躺著庄敛,像睡著了一般。 火紅的嫁衣襯著肌膚如雪科汗。 梳的紋絲不亂的頭發(fā)上藻烤,一...
    開封第一講書人閱讀 51,165評(píng)論 1 299
  • 那天,我揣著相機(jī)與錄音头滔,去河邊找鬼怖亭。 笑死,一個(gè)胖子當(dāng)著我的面吹牛坤检,可吹牛的內(nèi)容都是我干的兴猩。 我是一名探鬼主播,決...
    沈念sama閱讀 40,052評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼早歇,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼倾芝!你這毒婦竟也來了讨勤?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,910評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤晨另,失蹤者是張志新(化名)和其女友劉穎潭千,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體借尿,經(jīng)...
    沈念sama閱讀 45,324評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡刨晴,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,542評(píng)論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了路翻。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片狈癞。...
    茶點(diǎn)故事閱讀 39,711評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖茂契,靈堂內(nèi)的尸體忽然破棺而出亿驾,到底是詐尸還是另有隱情,我是刑警寧澤账嚎,帶...
    沈念sama閱讀 35,424評(píng)論 5 343
  • 正文 年R本政府宣布莫瞬,位于F島的核電站,受9級(jí)特大地震影響郭蕉,放射性物質(zhì)發(fā)生泄漏疼邀。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,017評(píng)論 3 326
  • 文/蒙蒙 一召锈、第九天 我趴在偏房一處隱蔽的房頂上張望旁振。 院中可真熱鬧,春花似錦涨岁、人聲如沸拐袜。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,668評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蹬铺。三九已至,卻和暖如春秉撇,著一層夾襖步出監(jiān)牢的瞬間甜攀,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,823評(píng)論 1 269
  • 我被黑心中介騙來泰國打工琐馆, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留规阀,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,722評(píng)論 2 368
  • 正文 我出身青樓瘦麸,卻偏偏與公主長得像谁撼,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子滋饲,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,611評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容