小程序promise封装post请求_Promise封装微信小程序的Request请求

回调地狱一向是影响开发和维护的症结所在,无数个success()的嵌套再嵌套,导致代码层级颇深,盘一次逻辑都要费劲千辛万苦,ES6语法中的Promise,便是专为解决JS中异步请求回调的信任问题而存在的,结合小程序目前提供的API支持,可以用Promise将其进行简单封装,优化性能体验。具体代码如下(注意看注释):

1. 首先在公共的util.js(或者自己创建的公有JS文件)中加入如下方法:

/**

* wxPromisify 使用promise封装request请求

* @fn 传入的函数,如wx.request、wx.download

*/

function wxPromisify(fn) {

return function(obj = {}) {

return new Promise((resolve, reject) => {

obj.success = function(res) { //网络通畅,请求发送成功

console.log(res)

if (res.data.code == 200) { //判断后台返回的状态码,若是成功,返回resolve()

return resolve(res)

} else { //若是返回错误的状态码,弹窗提示失败信息,并附带错误代码,以便快速定位问题所在

wx.showModal({

title: res.data.msg,

content: "错误码:" + res.dat

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值