promise化微信小程序api

发布时间:2019-06-08 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了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的公用函数

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 })

脚本宝典总结

以上是脚本宝典为你收集整理的promise化微信小程序api全部内容,希望文章能够帮你解决promise化微信小程序api所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。