使用Promise封装小程序wxrequest

42次阅读

共计 1491 个字符,预计需要花费 4 分钟才能阅读完成。

因为业务需要,每个 http 请求都要加上一个请求头,所以每次都要写很多重复的代码。

现在尝试把 wx.request 简单的封装了一下,调用一个 request 方法,每次请求自动携带 header 头信息,这样就省事多了,包含了常见的 get post put delete 四种请求方法,支持 Promise 方式调用。

封装代码

class request {constructor() {
    this._baseUrl = 'https://xxx.com/api';
    this._token = wx.getStorageSync('token');
    this._header = {'Authorization': 'Bearer' + token}
  }

  /**
   * GET 类型的网络请求
   */
  getRequest(url, data, header = this._header) {return this.requestAll(url, data, header, 'GET')
  }

  /**
   * DELETE 类型的网络请求
   */
  deleteRequest(url, data, header = this._header) {return this.requestAll(url, data, header, 'DELETE')
  }

  /**
   * PUT 类型的网络请求
   */
  putRequest(url, data, header = this._header) {return this.requestAll(url, data, header, 'PUT')
  }

  /**
   * POST 类型的网络请求
   */
  postRequest(url, data, header = this._header) {return this.requestAll(url, data, header, 'POST')
  }

  /**
   * 网络请求
   */
  requestAll(url, data, header, method) {return new Promise((resolve, reject) => {
      wx.request({
        url: this._baseUrl + url,
        data: data,
        header: header,
        method: method,
        success: (res => {if (res.statusCode === 200) {
            //200: 服务端业务处理正常结束
            resolve(res)
          } else {
            // 其它错误,提示用户错误信息
            reject(res)
          }
        }),
        fail: (res => {reject(res)
        })
      })
    })
  }
}

export default request

使用方法

在 app.js 中引入:

import request from './request.js'
App({myRequest(){return new request();
  }
})

然后在要使用的页面里引入使用即可:

const app = getApp();// 新建页面时 默认引入
const ajax = app.myRequest();// 初始化一个的 request() 实例

Page({data:{},
  onLoad(){this.getData();  
  },
  getData(){ajax.getRequest('/getList',{id: 1024}).then((res)=>{console.log(res);
    }).catch((err)=>{console.log(err);
    })
  }
})

使用方法也是异常简单

  • 比如 Get 请求就是:ajax.getRequest(url: String, data: Object);
  • 比如 Post 请求就是:ajax.postRequest(url: String, data: Object);

参考:
封装 wx.request

正文完
 0