小程序篇-wx自帶api接入Promise枫弟,提升編程體驗

前面說的話:玩過小程序的都知道小程序中的 api對象 都是以這樣的形式展示的阳掐,
這里以wx.request舉例

wx.request({
  url: '',
  success(){
  },
  fail(){ }
});

這樣就會帶來一些問題糊秆,比如你需要連續(xù)調(diào)用好幾個api武福,
回調(diào)地獄(Callback Hell)就來了

wx.request({
  url: '',
  success(){

    wx.request({
      url: '',
      success() { },
      fail() { }
    });
    
  },
  fail(){ }
});

如何解決這個問題呢?當(dāng)然還是用宇宙超級無敵的Promise了痘番。

新建一個wxp.js文件放置于你想放的地方捉片,
代碼如下:

const toPromise = (fn) => {
  // 這個api不是一個方法平痰,直接返回該api
  if (typeof fn !== 'function') return fn;
  return (args = {}) => {
    // 這個api的參數(shù)不是對象,直接返回方法(參數(shù))
    if (typeof args !== 'object') {
      return fn(args);
    }
    // 這個api是有sussess和fail這樣子的回調(diào)函數(shù) 就有promise方法
    return new Promise((resolve, reject) => {
      args.success = resolve;
      args.fail = reject;
      fn(args);
    });
  };
};
export default Object.keys(wx).reduce((o, name) => {
  o[name] = toPromise(wx[name]);
  return o;
}, {});

其他頁面調(diào)用

import wxp from '../../lib/wxp';
// ...



// ...
wxp.request({
  url: 'url1',
}).then((res) => {
  // url1 success
  return wxp.request({
    url: 'url2',
  });
}, (res) => {
  // url1 fail
}).then((res) => {
  // url2 success
}, (res) => {
  // url2 fail
});
// ...

其他的很多api就都可以用wxp的方式來調(diào)用了
這樣子伍纫,我們就解決了回調(diào)地獄了觉增。

當(dāng)要連續(xù)調(diào)用多個wx api的時候,我們還是采用es6的Promise特性翻斟,
讓代碼更好看逾礁,編程更愉悅。
——尼古拉斯·峰

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末访惜,一起剝皮案震驚了整個濱河市嘹履,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌债热,老刑警劉巖砾嫉,帶你破解...
    沈念sama閱讀 217,185評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異窒篱,居然都是意外死亡焕刮,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,652評論 3 393
  • 文/潘曉璐 我一進店門墙杯,熙熙樓的掌柜王于貴愁眉苦臉地迎上來配并,“玉大人,你說我怎么就攤上這事高镐「刃” “怎么了?”我有些...
    開封第一講書人閱讀 163,524評論 0 353
  • 文/不壞的土叔 我叫張陵嫉髓,是天一觀的道長观腊。 經(jīng)常有香客問我,道長算行,這世上最難降的妖魔是什么梧油? 我笑而不...
    開封第一講書人閱讀 58,339評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮州邢,結(jié)果婚禮上儡陨,老公的妹妹穿的比我還像新娘。我一直安慰自己偷霉,他們只是感情好迄委,可當(dāng)我...
    茶點故事閱讀 67,387評論 6 391
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著类少,像睡著了一般叙身。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上硫狞,一...
    開封第一講書人閱讀 51,287評論 1 301
  • 那天信轿,我揣著相機與錄音晃痴,去河邊找鬼。 笑死财忽,一個胖子當(dāng)著我的面吹牛倘核,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播即彪,決...
    沈念sama閱讀 40,130評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼紧唱,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了隶校?” 一聲冷哼從身側(cè)響起漏益,我...
    開封第一講書人閱讀 38,985評論 0 275
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎深胳,沒想到半個月后绰疤,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,420評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡舞终,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,617評論 3 334
  • 正文 我和宋清朗相戀三年轻庆,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片敛劝。...
    茶點故事閱讀 39,779評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡余爆,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出攘蔽,到底是詐尸還是另有隱情龙屉,我是刑警寧澤呐粘,帶...
    沈念sama閱讀 35,477評論 5 345
  • 正文 年R本政府宣布满俗,位于F島的核電站,受9級特大地震影響作岖,放射性物質(zhì)發(fā)生泄漏唆垃。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,088評論 3 328
  • 文/蒙蒙 一痘儡、第九天 我趴在偏房一處隱蔽的房頂上張望辕万。 院中可真熱鬧,春花似錦沉删、人聲如沸渐尿。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,716評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽砖茸。三九已至,卻和暖如春殴穴,著一層夾襖步出監(jiān)牢的瞬間凉夯,已是汗流浹背货葬。 一陣腳步聲響...
    開封第一講書人閱讀 32,857評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留劲够,地道東北人震桶。 一個月前我還...
    沈念sama閱讀 47,876評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像征绎,于是被迫代替她去往敵國和親蹲姐。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,700評論 2 354

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

  • title: promise總結(jié) 總結(jié)在前 前言 下文類似 Promise#then人柿、Promise#resolv...
    JyLie閱讀 12,239評論 1 21
  • 官方中文版原文鏈接 感謝社區(qū)中各位的大力支持淤堵,譯者再次奉上一點點福利:阿里云產(chǎn)品券,享受所有官網(wǎng)優(yōu)惠顷扩,并抽取幸運大...
    HetfieldJoe閱讀 8,681評論 0 29
  • 官方中文版原文鏈接 感謝社區(qū)中各位的大力支持拐邪,譯者再次奉上一點點福利:阿里云產(chǎn)品券,享受所有官網(wǎng)優(yōu)惠隘截,并抽取幸運大...
    HetfieldJoe閱讀 11,026評論 26 95
  • 那一年婶芭,應(yīng)該是夏天的东臀,我穿著工作丅恤的。 騎著二手捷安特的犀农。背包是買什么送的惰赋,包里放著一棵枙子樹苗,桔子樹苗呵哨,枇杷...
    吉草末閱讀 170評論 0 0
  • 今天2018年2月26日赁濒,爸爸媽媽一直叫我們過去吃福。下午我和孩子搭乘101路公交車到九湖花卉交易中心孟害,一會兒就到了拒炎。
    鄭淑玲laura閱讀 193評論 0 0