Promise的基本使用

基本概念

個人理解就是使用同步編程的寫法完成異步編程操作幢哨。

const promise = new Promise((resolve, reject) => {
    //some asynchronous  code
    setTimeout(() => {
        console.log('執(zhí)行完成');
        resolve('some data');
    }, 2000);
});

Promise 接收一個函數(shù)作為參數(shù)赡勘,函數(shù)有兩個參數(shù),resolvereject 分別表示異步操作執(zhí)行后成功的回調(diào)函數(shù)和失敗的回調(diào)函數(shù)捞镰。

Promise 實例后馬上執(zhí)行闸与。所以通常采用一個函數(shù)包含它

function runAsync() {
    return new Promise((resolve, reject) => {
        //some asynchronous  code
        setTimeout(() => {
            console.log('執(zhí)行完成');
            resolve('some data');
        }, 2000);
    });
}
runAsync().then((data) => {
    console.log(data);//可以使用異步操作中的數(shù)據(jù)
})

runAsync() 執(zhí)行完調(diào)用 then 方法,then() 就相當于我們之前寫的回調(diào)函數(shù)岸售。

resolve 和 reject

function paramTest(){
    return new Promise((resolve, reject) => {
        let number = Math.ceil(Math.random() * 10);
        if (number < 5) {
            resolve(number);
        }else{
            reject('out of range');
        }
    })
}
paramTest().then((number) => {
    console.log('resolved');
    console.log(number);
},(reason) => {
    console.log('rejected');
    console.log(reason);
})

Promise 有三種狀態(tài):pending(進行中)几迄、fulfilled(已成功)和 rejected(已失敗)

paramTest() 例子有兩種情況:

  • number < 5 時冰评,我們認為是成功情況映胁,將狀態(tài)從 pending 變?yōu)?fulfilled
  • number >= 5 時,我們認為是失敗情況甲雅,將狀態(tài)從 pending 變?yōu)?rejected

所以paramTest() 的執(zhí)行結(jié)果:

fulfilled rejected
resolved rejected
number out of range

catch的用法

我們繼續(xù)調(diào)用 paramTest 方法舉例

paramTest().then((number) => {
    console.log('resolved');
    console.log(number);
    console.log(data); //data為未定義
},(reason) => {
    console.log('rejected');
    console.log(reason);
}).catch((err) => {
    console.log(err);
})

catch 方法其實就是 .then(null, rejection) 的別名解孙,也是用來處理失敗失敗的回調(diào)函數(shù),但是還有一個作用:當 resolve 回調(diào)中如果出現(xiàn)錯誤了抛人,不會堵塞弛姜,會執(zhí)行 catch 中的回調(diào)。

all的用法

const p = Promise.all([p1, p2, p3]);

p.then(result => {
    console.log(result);
})

all 方法接收一個數(shù)組參數(shù)妖枚,數(shù)組中每一項返回的都是 Promise 對象廷臼,只有當 p1, p2, p3 都執(zhí)行完才會進入 then 回調(diào)。p1, p2, p3 返回的數(shù)據(jù)會以一個數(shù)組的形式傳到 then 回調(diào)中。

const p1 = new Promise((resolve, reject) => {
    setTimeout(() => {
        resolve('p1');
    }, 1000);
})
.then(result => result)
.catch(e => e);

const p2 = new Promise((resolve, reject) => {
    setTimeout(() => {
        resolve('p2');
    }, 3000);
})
.then(result => result)
.catch(e => e);

Promise.all([p1, p2])
.then(result => console.log(result))
.catch(e => console.log(e));
//3秒后輸出['p1', 'p2']

race的用法

const p = Promise.race([p1, p2, p3]);

p.then(result => {
    console.log(result);
})

race 的用法與 all 如出一轍荠商,不同的是 all 方法需要參數(shù)的每一項都返回成功了才會執(zhí)行 then;而 race 則是只要參數(shù)中的某一項返回成功就執(zhí)行 then 回調(diào)寂恬。

以下是 race 的例子,和 all 方法對比莱没,可以看到返回值有很明顯的區(qū)別初肉。

const p1 = new Promise((resolve, reject) => {
    setTimeout(() => {
        resolve('p1');
    }, 1000);
})
.then(result => result)
.catch(e => e);

const p2 = new Promise((resolve, reject) => {
    setTimeout(() => {
        resolve('p2');
    }, 3000);
})
.then(result => result)
.catch(e => e);

Promise.race([p1, p2])
.then(result => console.log(result))
.catch(e => console.log(e));
//1秒后輸出 'p1'

點擊這里查看本文中實例源代碼

resloader是基于Promise實現(xiàn)的一個圖片預(yù)加載并展示加載進度的插件,猛戳這里了解詳情饰躲。如果感覺還可以的話牙咏,歡迎star

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市嘹裂,隨后出現(xiàn)的幾起案子妄壶,更是在濱河造成了極大的恐慌,老刑警劉巖寄狼,帶你破解...
    沈念sama閱讀 218,607評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件盯拱,死亡現(xiàn)場離奇詭異,居然都是意外死亡例嘱,警方通過查閱死者的電腦和手機狡逢,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,239評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來拼卵,“玉大人奢浑,你說我怎么就攤上這事∫溉” “怎么了雀彼?”我有些...
    開封第一講書人閱讀 164,960評論 0 355
  • 文/不壞的土叔 我叫張陵,是天一觀的道長即寡。 經(jīng)常有香客問我徊哑,道長,這世上最難降的妖魔是什么聪富? 我笑而不...
    開封第一講書人閱讀 58,750評論 1 294
  • 正文 為了忘掉前任莺丑,我火速辦了婚禮,結(jié)果婚禮上墩蔓,老公的妹妹穿的比我還像新娘梢莽。我一直安慰自己,他們只是感情好奸披,可當我...
    茶點故事閱讀 67,764評論 6 392
  • 文/花漫 我一把揭開白布昏名。 她就那樣靜靜地躺著,像睡著了一般阵面。 火紅的嫁衣襯著肌膚如雪轻局。 梳的紋絲不亂的頭發(fā)上洪鸭,一...
    開封第一講書人閱讀 51,604評論 1 305
  • 那天,我揣著相機與錄音仑扑,去河邊找鬼览爵。 笑死,一個胖子當著我的面吹牛夫壁,可吹牛的內(nèi)容都是我干的拾枣。 我是一名探鬼主播沃疮,決...
    沈念sama閱讀 40,347評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼盒让,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了司蔬?” 一聲冷哼從身側(cè)響起邑茄,我...
    開封第一講書人閱讀 39,253評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎俊啼,沒想到半個月后肺缕,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,702評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡授帕,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,893評論 3 336
  • 正文 我和宋清朗相戀三年同木,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片跛十。...
    茶點故事閱讀 40,015評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡彤路,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出芥映,到底是詐尸還是另有隱情洲尊,我是刑警寧澤,帶...
    沈念sama閱讀 35,734評論 5 346
  • 正文 年R本政府宣布奈偏,位于F島的核電站坞嘀,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏惊来。R本人自食惡果不足惜丽涩,卻給世界環(huán)境...
    茶點故事閱讀 41,352評論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望裁蚁。 院中可真熱鬧内狸,春花似錦、人聲如沸厘擂。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,934評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽刽严。三九已至昂灵,卻和暖如春避凝,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背眨补。 一陣腳步聲響...
    開封第一講書人閱讀 33,052評論 1 270
  • 我被黑心中介騙來泰國打工管削, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人撑螺。 一個月前我還...
    沈念sama閱讀 48,216評論 3 371
  • 正文 我出身青樓含思,卻偏偏與公主長得像,于是被迫代替她去往敵國和親甘晤。 傳聞我的和親對象是個殘疾皇子含潘,可洞房花燭夜當晚...
    茶點故事閱讀 44,969評論 2 355

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

  • Promise 對象 Promise 的含義 Promise 是異步編程的一種解決方案痘系,比傳統(tǒng)的解決方案——回調(diào)函...
    neromous閱讀 8,706評論 1 56
  • 本文適用的讀者 本文寫給有一定Promise使用經(jīng)驗的人基协,如果你還沒有使用過Promise,這篇文章可能不適合你弦蹂,...
    HZ充電大喵閱讀 7,310評論 6 19
  • 目錄:Promise 的含義基本用法Promise.prototype.then()Promise.prototy...
    BluesCurry閱讀 1,494評論 0 8
  • 00、前言Promise 是異步編程的一種解決方案游沿,比傳統(tǒng)的解決方案——回調(diào)函數(shù)和事件——更合理和更強大饰抒。它由社區(qū)...
    夜幕小草閱讀 2,133評論 0 12
  • 他老了,皇帝準他告老返鄉(xiāng)诀黍。 他一生為官清廉袋坑,走的時候一身儒裝,兩袖空空蔗草,肩挎一只陳舊小包袱咒彤,此外再無其他。 不管當...
    幻三閱讀 589評論 5 3