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 })
新聞熱點
疑難解答