微信小程序:使用Promise簡化回調

封面

瞭解什麼是 Promise 對象node

在項目中,會出現各類異步操做,若是一個異步操做的回調裏還有異步操做,就會出現回調金字塔。git

好比下面這種

// 模擬獲取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的形式,全部有人封裝了這樣一個方法:es6

promisify.jsgithub

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=>{

})

getSystemInfo

能夠看到簡化後的回調裏少了一個縮進,而且回調函數從9行減小到了6行。api

回調金字塔的簡化效果

那麼再來看看最開始的那個回調金字塔promise

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等中。異步

參考

源代碼

相關文章
相關標籤/搜索