ECMAScript之Promise

學(xué)習(xí)Promise前我們先搞清楚這幾個(gè)單詞前标。

promise,resolve距潘,reject => 承諾炼列,解決,失敗音比。
pending(進(jìn)行中)俭尖、fulfilled(已成功)和rejected(已失敗)

不是我裝逼洞翩,只是為了你們別太low稽犁,自己谷歌一下這幾個(gè)單詞,然后好好發(fā)音骚亿,別發(fā)出撲若miss這種中不中西不西的奇怪發(fā)音已亥。

關(guān)鍵詞:異步編程。

隨著前端語(yǔ)言的進(jìn)化promise才誕生来屠,現(xiàn)在已經(jīng)統(tǒng)一了并且通用各大瀏覽器和規(guī)則虑椎。是異步編程截止18年來(lái)最好的解決方式之一。

ES6 規(guī)定俱笛,Promise對(duì)象是一個(gè)構(gòu)造函數(shù)绣檬,用來(lái)生成Promise實(shí)例。

先來(lái)一個(gè)小例子嫂粟,抄襲自阮一峰:

function timeout(ms){

    return new Promise((resolve, reject) => {

        setTimeout(resolve,ms,'done')

    })

}

timeout(2000).then((value) => { console.log(value) })

// => 兩秒后打印出done

大概就是我給一個(gè)承諾娇未,什么是承諾和諾言,可不是男人說(shuō)的愛(ài)你一萬(wàn)年星虹,程序是老實(shí)的零抬,人家說(shuō)我答應(yīng)你執(zhí)行這個(gè)就一定會(huì)執(zhí)行,不執(zhí)行我就會(huì)被干掉宽涌。那么實(shí)際例子中呢平夜?

實(shí)戰(zhàn)應(yīng)用

  • 需求,當(dāng)報(bào)銷人改變我們需要做出一系列操作(異常麻煩和繁瑣)

  • 問(wèn)題:因?yàn)楫惓B闊┑牟僮骱蛿?shù)據(jù)需要一定執(zhí)行時(shí)間卸亮,這個(gè)時(shí)候我們一個(gè)關(guān)鍵數(shù)據(jù)后臺(tái)最少要400毫秒后才能返回忽妒,而我們的一系列操作都基于這個(gè)數(shù)據(jù),這些操作就不干了,誰(shuí)尼瑪?shù)饶氵@么久段直,我們報(bào)錯(cuò)去了吃溅。所以我們這會(huì)兒需要做一個(gè)異步來(lái)解決這個(gè)問(wèn)題,也就是必須先拿到這個(gè)數(shù)據(jù)后才能執(zhí)行其他操作鸯檬。

// 方法
let initData = () => {

    return new Promise(){

        getData().then().catch();// 請(qǐng)求后臺(tái)獲取數(shù)據(jù)

        resolve();

    }

}

// 改變事件調(diào)用决侈,

initData().then(()=>{

    // 執(zhí)行七七八八的操作。

}).catch()

  • 關(guān)于Promis自帶方法
  • then() // 成功;
  • catch()// 失敗;
  • finally();// 成功和失敗都會(huì)執(zhí)行;
  • all();race();// 多個(gè) Promise 實(shí)例,
  • reject();// 返回一個(gè)新的 Promise 實(shí)例

經(jīng)典面試題:抄襲自不知名網(wǎng)友喧务,想知道正確答案請(qǐng)留言赖歌。

  • 理解promise嘗試得出打印結(jié)果(想知道答案的留言問(wèn)我)。
setTimeout(function() { console.log(1)  }, 0);

new Promise(function executor(resolve) {

    console.log(2);

    for( var i=0 ; i<10000 ; i++ ) {    i == 9999 && resolve(); }

    console.log(3);

}).then(function() {

    console.log(4);

});

console.log(5);
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末功茴,一起剝皮案震驚了整個(gè)濱河市庐冯,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌坎穿,老刑警劉巖展父,帶你破解...
    沈念sama閱讀 206,126評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異赁酝,居然都是意外死亡犯祠,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,254評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門(mén)酌呆,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)衡载,“玉大人,你說(shuō)我怎么就攤上這事隙袁√涤椋” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,445評(píng)論 0 341
  • 文/不壞的土叔 我叫張陵菩收,是天一觀的道長(zhǎng)梨睁。 經(jīng)常有香客問(wèn)我,道長(zhǎng)娜饵,這世上最難降的妖魔是什么坡贺? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,185評(píng)論 1 278
  • 正文 為了忘掉前任,我火速辦了婚禮箱舞,結(jié)果婚禮上遍坟,老公的妹妹穿的比我還像新娘。我一直安慰自己晴股,他們只是感情好愿伴,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,178評(píng)論 5 371
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著电湘,像睡著了一般隔节。 火紅的嫁衣襯著肌膚如雪鹅经。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 48,970評(píng)論 1 284
  • 那天怎诫,我揣著相機(jī)與錄音瘾晃,去河邊找鬼。 笑死刽虹,一個(gè)胖子當(dāng)著我的面吹牛酗捌,可吹牛的內(nèi)容都是我干的呢诬。 我是一名探鬼主播涌哲,決...
    沈念sama閱讀 38,276評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼尚镰!你這毒婦竟也來(lái)了阀圾?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 36,927評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤狗唉,失蹤者是張志新(化名)和其女友劉穎初烘,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體分俯,經(jīng)...
    沈念sama閱讀 43,400評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡肾筐,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,883評(píng)論 2 323
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了缸剪。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片吗铐。...
    茶點(diǎn)故事閱讀 37,997評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖杏节,靈堂內(nèi)的尸體忽然破棺而出唬渗,到底是詐尸還是另有隱情,我是刑警寧澤奋渔,帶...
    沈念sama閱讀 33,646評(píng)論 4 322
  • 正文 年R本政府宣布镊逝,位于F島的核電站,受9級(jí)特大地震影響嫉鲸,放射性物質(zhì)發(fā)生泄漏撑蒜。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,213評(píng)論 3 307
  • 文/蒙蒙 一玄渗、第九天 我趴在偏房一處隱蔽的房頂上張望座菠。 院中可真熱鬧,春花似錦捻爷、人聲如沸辈灼。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,204評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)巡莹。三九已至司志,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間降宅,已是汗流浹背骂远。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,423評(píng)論 1 260
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留腰根,地道東北人激才。 一個(gè)月前我還...
    沈念sama閱讀 45,423評(píng)論 2 352
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像额嘿,于是被迫代替她去往敵國(guó)和親瘸恼。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,722評(píng)論 2 345

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

  • title: promise總結(jié) 總結(jié)在前 前言 下文類似 Promise#then册养、Promise#resolv...
    JyLie閱讀 12,221評(píng)論 1 21
  • 目錄:Promise 的含義基本用法Promise.prototype.then()Promise.prototy...
    BluesCurry閱讀 1,488評(píng)論 0 8
  • Promise含義 Promise是異步編程的一種解決方案东帅,比傳統(tǒng)的解決方案——回調(diào)函數(shù)和事件——更強(qiáng)大。所謂Pr...
    oWSQo閱讀 1,083評(píng)論 0 4
  • 00、前言Promise 是異步編程的一種解決方案坎炼,比傳統(tǒng)的解決方案——回調(diào)函數(shù)和事件——更合理和更強(qiáng)大愧膀。它由社區(qū)...
    夜幕小草閱讀 2,127評(píng)論 0 12
  • 好累,好累啊 一個(gè)人一個(gè)人一個(gè)人 是自己把自己逼的要面對(duì)那么多谣光,還是自己太笨太弱了檩淋,要一個(gè)人去面對(duì)這么多 累,好累
    小宇宙2014閱讀 142評(píng)論 0 0