【微信小程序】Promise封装请求

2019-04-30  本文已影响0人  u5f20u5929u8000

Promise 是异步编程的一种解决方案,比传统的解决方案——回调函数和事件——更合理和更强大。

Promise对象有以下两个特点:

(1)对象的状态不受外界影响。Promise对象代表一个异步操作,有三种状态:pending(进行中)、fulfilled(已成功)和rejected(已失败)。只有异步操作的结果,可以决定当前是哪一种状态,任何其他操作都无法改变这个状态。这也是Promise这个名字的由来,它的英语意思就是“承诺”,表示其他手段无法改变。

(2)一旦状态改变,就不会再变,任何时候都可以得到这个结果。Promise对象的状态改变,只有两种可能:从pending变为fulfilled和从pending变为rejected。只要这两种情况发生,状态就凝固了,不会再变了,会一直保持这个结果,这时就称为 resolved(已定型)。如果改变已经发生了,你再对Promise对象添加回调函数,也会立即得到这个结果。这与事件(Event)完全不同,事件的特点是,如果你错过了它,再去监听,是得不到结果的。

缺点:

Promise也有一些缺点。首先,无法取消Promise,一旦新建它就会立即执行,无法中途取消。其次,如果不设置回调函数,Promise内部抛出的错误,不会反应到外部。第三,当处于pending状态时,无法得知目前进展到哪一个阶段(刚刚开始还是即将完成)。

一、在utils文件夹下创建一个tools.js,代码如下:
/**
 * 工具类
 */
// 服务器地址
const hostApi = ''

/**
 * @封装http请求方法
 * @params 形参,是一个对象
 * {
 *   url: '',           //接口,必传
 *   method: '',       //方法,默认为GET,可选
 *   data: ''         //数据,可选
 * }
 */
const http = (params) => {
  // 返回Primise对象
  return new Promise((resolve, reject) => {
    wx.showLoading({
      title: '加载中',
      mask: true
    })
    let method = params.method || 'GET'
    const SUCCESS_STATUS = 200
    wx.request({
      url: hostApi + params.url,
      method: method,
      data: params.data || {},
      header: {
        'content-type': Object.is(method, 'GET') ? 'application/json' : 'application/x-www-form-urlencoded'
      },
      success: res => {
        if (Object.is(res.statusCode, SUCCESS_STATUS)) {
          wx.hideLoading()
          resolve(res.data)
        }
      },
      fail: err => {
        wx.hideLoading()
        showError()
        reject(err)
      }
    })
  })
}

/**
 * 弹窗提示网络错误
 */
function showError() {
  wx.showToast({
    title: '加载失败',
    icon: 'none',
    duration: 2000,
    mask: true
  })
}

module.exports = {
  http
}
2、在小程序app.js里配置全局函数
//app.js
const req = require('/utils/tools.js')  //引入创建的tools.js文件

App({
  onLaunch: function () {
    // 展示本地存储能力
    var logs = wx.getStorageSync('logs') || []
    logs.unshift(Date.now())
    wx.setStorageSync('logs', logs)

    // 登录
    wx.login({
      success: res => {
        // 发送 res.code 到后台换取 openId, sessionKey, unionId
      }
    })
    // 获取用户信息
    wx.getSetting({
      success: res => {
        if (res.authSetting['scope.userInfo']) {
          // 已经授权,可以直接调用 getUserInfo 获取头像昵称,不会弹框
          wx.getUserInfo({
            success: res => {
              // 可以将 res 发送给后台解码出 unionId
              this.globalData.userInfo = res.userInfo

              // 由于 getUserInfo 是网络请求,可能会在 Page.onLoad 之后才返回
              // 所以此处加入 callback 以防止这种情况
              if (this.userInfoReadyCallback) {
                this.userInfoReadyCallback(res)
              }
            }
          })
        }
      }
    })
  },
  globalData: {
    userInfo: null
  },
  api: {  //封装接口
    
  },
  http: {   //配置全局变量
    req: req.http
  }
})
3、在项目代码中调用方法
app.http.req(params).then(res => {
  //返回结果的处理逻辑
  console.log(res)
  ...
})
上一篇下一篇

猜你喜欢

热点阅读