瞭解什麼是 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) } })
由於微信小程序異步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=>{ })
能夠看到簡化後的回調裏少了一個縮進,而且回調函數從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等中。異步
promisePage
頁面