JS中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的公用函数
functionpromisify(method,options={}){
returnnewPromise((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})热门推荐
10 祝女儿简短祝福语大全
11 大学新年祝福语简短创意
12 元旦适合的祝福语简短
13 朋友出远门祝福语简短
14 初六简短的祝福语
15 祝男孩生日祝福语简短
16 同事调离的祝福语简短
17 拜年红包的祝福语简短
18 妈妈生日祝福语简短励志