為Promise添加一個方法

Promise在JS中可以說有著舉足輕重的地位驶社,很早之前就看了很多Promise的文章和書籍艰毒,記得在一篇文章中看到過Promise的list方法(作用下邊有詳細(xì)介紹)還做了筆記裁着,但是伦吠,在使用的時候卻發(fā)現(xiàn)現(xiàn)在的JS標(biāo)準(zhǔn)(ES6)不支持list方法赫段,所以舵抹,就自己寫一個吧背蟆!哈哈哈哈哈

Promise.list():

作用:將多個Promise對象包裝成一個新的Promise對象鉴分,并行運行多個Promise對象,所有Promise對象結(jié)束觸發(fā)then事件带膀。主要功能:若有Promise對象出錯(list方法的重點)志珍,則包裝為

{ error: "error msg" }    // 錯誤信息

正確則返回結(jié)果。

示例:

var p = Promise.list([p1,p2,p3]);

p.then(function(values) {
    // values為[{p1的結(jié)果},{p2的結(jié)果},{p3的結(jié)果}]
})

接受參數(shù): 一個數(shù)組垛叨,數(shù)組每一項為Promise對象伦糯,如p1、p2嗽元、p3敛纲。

返回結(jié)果: 一個數(shù)組,順序排列每一項的結(jié)果剂癌。

實現(xiàn):

// 原始版
if (!Promise.list) {
    Promise.list = function (jobArr) {
        let jobsResult = [];
        jobArr.forEach(function (job) {

            // 運行數(shù)組內(nèi)的Promise對象淤翔,出現(xiàn)錯誤包裝為{"error": reason}
            jobsResult.push(job.then(function (value) {
                return value;
            }).catch(function (reason) {
                return {"error": reason};
            }));
        })

        // 用Promise.all包裝為一個新的Promise對象
        return Promise.all(jobsResult);
    }
}

// 精簡版
if (!Promise.list) {
    Promise.list = list => Promise.all( list.map( item => item.then(val => ({val})).catch(err => ({err}))));
}

使用示例:

// 添加Promise.list方法
if (!Promise.list) {
    Promise.list = function (jobArr) {
        let jobsResult = [];
        jobArr.forEach(function (job) {
            jobsResult.push(job.then(function (value) {
                return value;
            }).catch(function (reason) {
                return {"error": reason};
            }));
        })
        return Promise.all(jobsResult);
    }
}

// 創(chuàng)建一個數(shù)組,每一項為Promise對象
var pArr = [1, 2, 3, 4].map(function (value) {
    if (value == 3) {    // 第三個設(shè)置為會出錯的Promise對象
        return createPromise(0);
    } else {
        return createPromise(1);
    }
})

// 創(chuàng)建Promise對象的方法珍手,returnStatus為1返回正確的Promise對象办铡,其他則返回錯誤的Promise對象
function createPromise(returnStatus) {
    return new Promise(function (reslove, reject) {
        if (returnStatus == 1) {
            reslove({data: "success"});
        } else {
            reject("failed");
        }
    });
}

// 調(diào)用Promise.list()方法
Promise.list(pArr).then(function (value) {
    console.log("value:", value);    // 第三個會返回錯誤信息:[ { data: 'success' },{ data: 'success' },{ error: 'failed' },{ data: 'success' } ]
}).catch(function (reason) {
    console.log("error:", reason);
})

總結(jié): 歡迎指教。哈哈哈哈哈

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末琳要,一起剝皮案震驚了整個濱河市寡具,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌稚补,老刑警劉巖童叠,帶你破解...
    沈念sama閱讀 211,817評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡厦坛,警方通過查閱死者的電腦和手機五垮,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,329評論 3 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來杜秸,“玉大人放仗,你說我怎么就攤上這事∏说” “怎么了诞挨?”我有些...
    開封第一講書人閱讀 157,354評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長呢蛤。 經(jīng)常有香客問我惶傻,道長,這世上最難降的妖魔是什么其障? 我笑而不...
    開封第一講書人閱讀 56,498評論 1 284
  • 正文 為了忘掉前任银室,我火速辦了婚禮,結(jié)果婚禮上励翼,老公的妹妹穿的比我還像新娘蜈敢。我一直安慰自己,他們只是感情好汽抚,可當(dāng)我...
    茶點故事閱讀 65,600評論 6 386
  • 文/花漫 我一把揭開白布扶认。 她就那樣靜靜地躺著,像睡著了一般殊橙。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上狱从,一...
    開封第一講書人閱讀 49,829評論 1 290
  • 那天膨蛮,我揣著相機與錄音,去河邊找鬼季研。 笑死敞葛,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的与涡。 我是一名探鬼主播惹谐,決...
    沈念sama閱讀 38,979評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼驼卖!你這毒婦竟也來了氨肌?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,722評論 0 266
  • 序言:老撾萬榮一對情侶失蹤酌畜,失蹤者是張志新(化名)和其女友劉穎怎囚,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體桥胞,經(jīng)...
    沈念sama閱讀 44,189評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡恳守,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,519評論 2 327
  • 正文 我和宋清朗相戀三年考婴,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片催烘。...
    茶點故事閱讀 38,654評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡沥阱,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出伊群,到底是詐尸還是另有隱情考杉,我是刑警寧澤,帶...
    沈念sama閱讀 34,329評論 4 330
  • 正文 年R本政府宣布在岂,位于F島的核電站奔则,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏蔽午。R本人自食惡果不足惜易茬,卻給世界環(huán)境...
    茶點故事閱讀 39,940評論 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望及老。 院中可真熱鬧抽莱,春花似錦、人聲如沸骄恶。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,762評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽僧鲁。三九已至虐呻,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間寞秃,已是汗流浹背斟叼。 一陣腳步聲響...
    開封第一講書人閱讀 31,993評論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留春寿,地道東北人朗涩。 一個月前我還...
    沈念sama閱讀 46,382評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像绑改,于是被迫代替她去往敵國和親谢床。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,543評論 2 349

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

  • 官方中文版原文鏈接 感謝社區(qū)中各位的大力支持厘线,譯者再次奉上一點點福利:阿里云產(chǎn)品券识腿,享受所有官網(wǎng)優(yōu)惠,并抽取幸運大...
    HetfieldJoe閱讀 8,677評論 0 29
  • ??引用類型的值(對象)是引用類型的一個實例。 ??在 ECMAscript 中,引用類型是一種數(shù)據(jù)結(jié)構(gòu)硝全,用于將數(shù)...
    霜天曉閱讀 1,044評論 0 1
  • 我愛你伟众, 不光因為你的樣子析藕, 還因為, 和你在一起時凳厢, 我的樣子账胧。 不可否認(rèn),這篇短文充滿了對林楚楚的溢美之辭先紫,但...
    吟嘯慢行閱讀 307評論 0 1
  • 知道自己做什么治泥,PDCA簡單的重復(fù)。就是循序漸進遮精,不斷更新居夹。外求不滅,內(nèi)修不生本冲。
    十年一井閱讀 136評論 0 0
  • 我們都玩過傳話游戲准脂,好好的一句話傳到最后一個人,基本是面目全非檬洞。老媽家裝修也犯了這個毛病狸膏。因為裝修是親戚介紹,老媽...
    水靜花間閱讀 138評論 0 0