微信小程序之封装HTTP请求(升级版)

  • Post author:
  • Post category:小程序


原版:

微信小程序之封装HTTP请求


上代码

// 该函数怎么写,需要跟后端人员协商返回的格式
function getErrorMsgByErrorNo(error_no) {
  let error_msg;
  switch (error_no) {
    case 100: error_msg = '操作失败,请稍后再试!'; break;
    default: error_msg = '网络错误,请稍后再试!'; break;
  }
  return error_msg;
}
function handleData(res) {
  if (res.data.success) {
    if (typeof (res.data.body) === 'string') {
      return [];
    } else if (Array.isArray(res.data.body) === false) {
      const _arr = [];
      _arr.push(res.data.body);
      return _arr;
    } else {
      return res.data.body;
    }
  } else {
    if (res.data.error_no) {
      return {
        error_no: res.data.error_no,
        error_msg: getErrorMsgByErrorNo(res.data.error_no)
      };
    } else {
      return {
        error_no: 123456,
        error_msg: '服务器维护中,请稍后!'
      };
    }
  }
}

const httpClient = {
  request: function (method, url, data) {
    return new Promise((resolve, reject) => {
      wx.request({
        url: url,
        data: data,
        method: method,
        success: function (res) {
          resolve(handleData(res))
        },
        fail: function (err) {
          console.log('request fail ', err);
          resolve({
            error_no: 100,
            error_msg: getErrorMsgByErrorNo(100)
          })
        },
        complete: function (res) {
          console.log("request completed!");
        }
      })
    });
  },
  get: function (url) {
    return this.request('GET', url);
  },
  post: function (url, data) {
    return this.request('POST', url, data);
  },
  put: function (url, data) {
    return this.request('PUT', url, data);
  },
  delete: function (url, data) {
    return this.request('DELETE', url, data);
  },
};

module.exports = httpClient;

使用

function getMyselfData() {
  const _Url= urls.url;
  return httpClient.get(_Url);
}

 getData() {
    let resultsData = this.getMyselfData();
    resultsData.then((res) => {
      if (res.error_no) {
      // 只要有error_no就说明请求出现了错误
        this.toast.showToast({
          type: 'fail',
          title: res.error_msg,
        })
      } else {
        this.setData({
          journeyList: res.data
        })
      }
    });
  },



版权声明:本文为zhy13087344578原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。