vue es6關(guān)于promise的項(xiàng)目實(shí)戰(zhàn)。

學(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í)際例子中呢?

需求,當(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í)行其他操作。

方法:

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í)例


面試題:抄襲自不知名網(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)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Promise 對(duì)象 Promise 的含義 Promise 是異步編程的一種解決方案,比傳統(tǒng)的解決方案——回調(diào)函...
    neromous閱讀 8,823評(píng)論 1 56
  • 本文適用的讀者 本文寫(xiě)給有一定Promise使用經(jīng)驗(yàn)的人,如果你還沒(méi)有使用過(guò)Promise,這篇文章可能不適合你,...
    HZ充電大喵閱讀 7,444評(píng)論 6 19
  • 特點(diǎn) Promise能將回調(diào)分離出來(lái),在異步操作執(zhí)行之后,用鏈?zhǔn)椒椒▓?zhí)行回調(diào),雖然es5用封裝函數(shù)也能實(shí)現(xiàn),但是如...
    一二三kkxx閱讀 714評(píng)論 0 1
  • 前言 本文旨在簡(jiǎn)單講解一下javascript中的Promise對(duì)象的概念,特性與簡(jiǎn)單的使用方法。并在文末會(huì)附上一...
    _暮雨清秋_閱讀 2,312評(píng)論 0 3
  • ES6 Promise 用法講解 Promise是一個(gè)構(gòu)造函數(shù),自己身上有all、reject、resolve這幾...
    這刻我懂了閱讀 695評(píng)論 0 1

友情鏈接更多精彩內(nèi)容