微信小程序的api用的是對象參數回調模式,很容易形成回調地獄,代碼難以閱讀,判斷,修改 和調試.小程序
// 獲取用戶信息 wx.getSetting({ success: res => { if (res.authSetting['scope.userInfo']) { // 已經受權,能夠直接調用 getUserInfo 獲取頭像暱稱,不會彈框 wx.getUserInfo({ success: res => { // 能夠將 res 發送給後臺解碼出 unionId this.globalData.userInfo = res.userInfo } }) } } })
能夠看出兩層的時候,代碼就很彆扭了微信小程序
編寫一個能夠promise小程序api的公用函數api
function promisify (method, options = {}) { return new Promise((resolve, reject) => { // 將options對象賦值 而後再傳給下面調用的方法中 options.success = resolve options.fail = err => { reject(err) } wx[method](options) }) }
傳遞的額外參數經過對象解構方式傳遞promise
promisify('getUserInfo') .then((res) => console.log(res)) .catch((err) => {console.error(err)}) promisify('navigateTo', { url })