promise化微信小程序api

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的公用函數api

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

使用示例

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

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

promisify('navigateTo', { url })
相關文章
相關標籤/搜索