微信小程序基于Promise封装wx.request请求(完整代码)

wx.request完整代码
wx.request({
  url: 'url',// 请求地址
  header:{// 请求头
    'content-type':'application/json'
  },
  method:'POST',// 请求方法
  data:{
    // 请求参数
  },
  success:res=>{
    console.log('成功',res);
  },
  fail:err=>{
    console.log('失败回调',err);
  },
  complete(){
    console.log('回调成功与否都会执行')
  }
})

如果每个需要网络请求的地方我们都使用官方提供的wx.request请求,大大的增加了代码量。使用Promise方法封装wx.request哪就可以使用Promise的then()方法来获取成功回调catch()获取失败回调,废话不多说,直接上代码。

新建一个api文件夹,在api文件夹下创建一个request.js文件把wx.request用promise方法封装起来
const baseURL = "请求基础路径"

export function request(options){
  return new Promise((resolve,reject)=>{
    wx.request({
      url: baseURL + options.url,
      data:options.data || {},
      method:options.method || 'get',
      success:res=>{
        resolve(res)
      },
      fail:err=>{
        reject(err)
      }
    })
  })
}
api文件夹内再创建一个index.js文件,把不同的请求方法都放着统一管理
import {request} from './request'

export function getList(data){
  return request({
    url:'/upload',
    header:{
      'content-type':'application/json'
       // 如有token的需求可以在此处携带,也可以在request.js定义
    },
    data:data,
    method:'post'
  })
}
使用时通过import 导入的方法,把在api文件夹下创建的index.js导入使用
import {getList} from '../../api/index'

getList().then(res=>{console.log('成功回调',res)}).catch(err=>{console.log('失败回调',err)})

这样我们的wx.request就精简很多啦,以后维护起来也跟方便

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值