解决小程序 callback hell

让我们先回顾一下 callback

写一个授权通用方法。

const _authHandle = (setting ,callback) => {
    wx.getSetting({
        success: (response) => {
            if (response.authSetting[setting]) {
                return callback(true)
            }

            wx.authorize({
                scope: setting,
                success: () => {
                    return callback(true)
                },
                fail: () => {
                    return callback(false)
                }
            })
        }
    })
}
复制代码

usage

_authHandle('scope.userInfo',(result) => {
  console.log(result)
})
复制代码

Promise

我们用 promise 稍微修改一下之前的函数~

const _authHandle = (setting) => {
    return new Promise((resolve, reject) => {
        wx.getSetting({
            success: (response) => {
                if (response.authSetting[setting]) {
                    resolve(true)
                }
    
                wx.authorize({
                    scope: setting,
                    success: () => {
                        resolve(true)
                    },
                    fail: () => {
                        reject(false)
                    }
                })
            }
        })
    })
}
复制代码

usage

_authHandle('scope.userInfo')
    .then(res => {
        // res
    })
    .catch(err => {
        // err
    })
复制代码

async/await

原生小程序里面使用 async/await ,需要引入 facebook 的 regenerator-runtime

去 github 上把文件下到 lib 文件内,可以新建一个叫 runtime 的文件夹,丢进去。

import regeneratorRuntime from'../../lib/runtime.js'
复制代码

usage

async onTapAuth () {
    await _authHandle('scope.userInfo')
        .then(() => {
            // yes
        })
        .catch(() => {
            // no
        })
}
复制代码

注意: await 总是返回一个 Promise 对象,所以可以使用 then catch 捕获异常,或者使用同步 try catch 捕获异常。推荐使用 then catch

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值