小程序request请求封装

简介:最近需要写一个小程序的项目,为了方便节省代码就将request请求进行了封装
分析:首先将request请求封装到一个文件里,再将api单独设立一个文件,按功能统一分类放置,为了不产生回调地狱的问题,将request利用promise进行封装
详细过程:

  1. 首先在utils下新建一个request.js文件,用来封装request请求
    在这里插入图片描述
    然后在文件里面放入如下代码
const app = getApp()   // 获取app中的实例,为了拿到全局数据,url的基准值

const request = (url,options) => {
   return new Promise((resolve, reject) => {
     const { data, method } = options
     if(data && method.toLowerCase() !== 'get') {   // 判断是否是post方法
       options.data = JSON.stringify(data)
     }
       wx.request({
           url: `${app.globalData.baseUrl}${url}`,
           ...options,
           header: {
               'Content-Type': 'application/json; charset=UTF-8',
               'cookie': wx.getStorageSync("token")  // 看自己是否需要
           },
           success(res) {
               if (200 <= res.statusCode < 400) {
                   resolve(res.data)
               } else {
                   reject(res.data)
               }
           },
           fail(error) {
               reject(error.data)
           }
       })
   })
}

const get = (url, options = {}) => {
    return request(url, { method: 'GET', data: options })
 }
 
 const post = (url, options) => {
    return request(url, { method: 'POST', data: options })
 }
 
 const put = (url, options) => {
    return request(url, { method: 'PUT', data: options })
 }
 
 // 不能声明DELETE(关键字)
 const remove = (url, options) => {
    return request(url, { method: 'DELETE', data: options })
 }
 module.exports = {
    get,
    post,
    put,
    remove
 }
  1. 将基准地址写到全局数据里(也可以写在封装的request文件里)
    在这里插入图片描述在这里插入图片描述
  2. 再新建一个api文件夹,按功能模块存放不同的api,导入request文件放入url和参数数据就可以了
    在这里插入图片描述在这里插入图片描述
  3. 在文件中使用这个api的时候,就先导入文件,然后利用async和await函数调用这个接口,传入data参数就可以了
    在这里插入图片描述在这里插入图片描述
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值