详解JS中promise化微信小程序api

这篇文章主要给大家通过代码实例分析了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
}//欢迎加入前端全栈开发交流圈一起学习交流:864305860
})//面向1-3年前端人员
}//帮助突破技术瓶颈,提升思维能力
}
})

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

promise化小程序

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

function promisify (method, options = {}) {
return new Promise((resolve, reject) => {
// 将options对象赋值 然后再传给下面调用的方法中
options.success = resolve
options.fail = err => {
reject(err)
}//欢迎加入前端全栈开发交流圈一起学习交流:864305860
wx[method](options)
})//面向1-3年前端人员
}//帮助突破技术瓶颈,提升思维能力

使用示例

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

promisify(``'getUserInfo'``)

.then((res) => console.log(res))

.``catch``((err) => {console.error(err)})

promisify(``'navigateTo'``, { url })

结语

感谢您的观看,如有不足之处,欢迎批评指正。

猜你喜欢

转载自my.oschina.net/u/4018697/blog/2967665