国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

JS中promise化微信小程序api

2019-11-19 14:01:52
字體:
來源:轉載
供稿:網友

promise化的原因

微信小程序的api用的是對象參數回調模式,很容易造成回調地獄,代碼難以閱讀,判斷,修改 和調試.

微信小程序api示例

// 獲取用戶信息  wx.getSetting({   success: res => {    if (res.authSetting['scope.userInfo']) {     // 已經授權,可以直接調用 getUserInfo 獲取頭像昵稱,不會彈框     wx.getUserInfo({      success: res => {       // 可以將 res 發送給后臺解碼出 unionId       this.globalData.userInfo = res.userInfo      }     })    }   }  })

可以看出兩層的時候,代碼就很別扭了

promise化小程序

編寫一個可以promise小程序api的公用函數

function promisify (method, options = {}) { return new Promise((resolve, reject) => {  // 將options對象賦值 然后再傳給下面調用的方法中  options.success = resolve  options.fail = err => {   reject(err)  }  wx[method](options) })}

使用示例

傳遞的額外參數通過對象解構方式傳遞

promisify('getUserInfo') .then((res) => console.log(res)) .catch((err) => {console.error(err)})promisify('navigateTo', { url })

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 安塞县| 麻阳| 长沙市| 台江县| 天全县| 静安区| 庆阳市| 十堰市| 汉阴县| 岐山县| 佛坪县| 廉江市| 古蔺县| 荥阳市| 大城县| 河曲县| 新河县| 楚雄市| 重庆市| 阳信县| 乐都县| 凤台县| 白水县| 岫岩| 金阳县| 墨玉县| 周至县| 岢岚县| 台江县| 腾冲县| 丰原市| 靖西县| 莱芜市| 慈溪市| 九江县| 隆德县| 麻阳| 商洛市| 定襄县| 呼和浩特市| 航空|