推荐设备MORE

html 网页模板

html 网页模板

疑难问题

微信小程序的优点_JS中promise化微信小程序api

日期:2021-01-08
我要分享
JS中promise化微信小程序api     投稿:laozhang   这篇文章主要给大家通过代码实例分析了promise化微信小程序api的使用方法,对此有需要的朋友可以参考学习下。

微信小程序的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对象赋值 然后再传给下面调用的方法中
 ess = resolve
 options.fail = err = {
 reject(err)
 wx[method](options)
}

使用示例

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

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