微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

JS中promise化微信小程序api

promise化的原因

微信小程序的api用的是对象参数回调模式,很容易造成回调地狱,代码难以阅读,判断,修改 和调试.

微信小程序api示例

{ if (res.authSetting['scope.userInfo']) { // 已经授权,可以直接调用 getUserInfo 获取头像昵称,不会弹框 wx.getUserInfo({ success: res => { // 可以将 res 发送给后台解码出 unionId this.globalData.userInfo = res.userInfo } }) } } })

可以看出两层的时候,代码就很别扭了

promise化小程序

编写一个可以promise小程序api的公用函数

{ // 将options对象赋值 然后再传给下面调用方法中 options.success = resolve options.fail = err => { reject(err) } wx[method](options) }) }

使用示例

传递的额外参数通过对象解构方式传递

console.log(res)) .catch((err) => {console.error(err)})

promisify('navigateto',{ url })

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。