黔优媒体网-软文媒体自助发稿平台!
  1. 行业资讯
  2. 正文

使用Promise简化回调

来源:黔优媒体网   时间:2024-09-19

在项目中,会出现各种异步操作,如果一个异步操作的回调里还有异步操作,就会出现回调金字塔。

比如下面这种
// 模拟获取code,然后将code传给后台,成功后获取userinfo,再将userinfo传给后台
// 登录
wx.login({
    success: res =  {
        let code = res.code
        // 请求
        imitationPost({
            url: '/test/loginWithCode',
            data: {
                code
            },
            success: data =  {
                // 获取userInfo
                wx.getUserInfo({
                    success: res =  {
                        let userInfo = res.userInfo
                        // 请求
                        imitationPost({
                            url: '/test/saveUserInfo',
                            data: {
                                userInfo
                            },
                            success: data =  {
                                console.log(data)
                            },
                            fail: res =  {
                                console.log(res)
                            }
                        })
                    },
                    fail: res =  {
                        console.log(res)
                    }
                })
            },
            fail: res =  {
                console.log(res)
            }
        })
    },
    fail: res =  {
        console.log(res)
    }
})
下面分析如何用Promise来进行简化代码

因为微信小程序异步api都是success和fail的形式,所有有人封装了这样一个方法:

promisify.js

module.exports = (api) =  {
    return (options, ...params) =  {
        return new Promise((resolve, reject) =  {
            api(Object.assign({}, options, { success: resolve, fail: reject }), ...params);
        });
    }
}

先看最简单的:

// 获取系统信息
wx.getSystemInfo({
    success: res =  {
        // success
        console.log(res)
    },
    fail: res =  {
    }
})

使用上面的promisify.js简化后:

const promisify = require('./promisify')
const getSystemInfo = promisify(wx.getSystemInfo)
getSystemInfo().then(res= {
    // success
    console.log(res)
}).catch(res= {
})

可以看到简化后的回调里少了一个缩进,并且回调函数从9行减少到了6行。

回调金字塔的简化效果

那么再来看看最开始的那个回调金字塔

const promisify = require('./promisify')
const login = promisify(wx.login)
const getSystemInfo = promisify(wx.getSystemInfo)
// 登录
login().then(res =  {
    let code = res.code
    // 请求
    pImitationPost({
        url: '/test/loginWithCode',
        data: {
            code
        },
    }).then(data =  {
        // 获取userInfo
        getUserInfo().then(res =  {
            let userInfo = res.userInfo
            // 请求
            pImitationPost({
                url: '/test/saveUserInfo',
                data: {
                    userInfo
                },
            }).then(data =  {
                console.log(data)
            }).catch(res =  {
                console.log(res)
            })
        }).catch(res =  {
            console.log(res)
        })
    }).catch(res =  {
        console.log(res)
    })
}).catch(res =  {
    console.log(res)
})

可以看到简化效果非常明显。

同样适用于网页或者nodejs等中。

相关推荐:

Promise简化回调实例分享

微信小程序getUserInfo回调详解

jQuery回调方法使用详解

以上就是使用Promise简化回调的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。


上一篇: 没有了
下一篇:没有了
【免责申明】黔优媒体网以上展示内容来源于用户自主上传、合作媒体、企业机构或网络收集整理,版权争议与本站无关,文章涉及见解与观点不代表黔优媒体网官方立场,请读者仅做参考,本文标题:使用Promise简化回调;欢迎转载,转载时请说明出处。若您认为本文侵犯了您的版权信息,或您发现该内容有任何违法/违规的内容,请您立即联系我们及时修正或删除。(邮箱号: kefu@qianu.com)