详解微信小程序网络请求接口封装实例
作者:Acoe 发布时间:2024-06-12 04:08:54
标签:微信小程序,网络封装
网络请求封装实例
实现定制要求和方便调用,对微信小程序的网络请求接口进行了封装
封装位置:app.js,方便全局调用
实现方法调用,只用关注接口url和入参
默认和自定义的请求成功、失败和完成的回调处理
可设置请求失败自动重新请求的次数
可以防止重复提交
每个请求设定requestCode
代码
直接将这个方法放在了app.js中
/**
* 接口公共访问方法
* @param {Object} urlPath 访问路径
* @param {Object} params 访问参数(json格式)
* @param {Object} requestCode 访问码,返回处理使用
* @param {Object} onSuccess 成功回调
* @param {Object} onErrorBefore 失败回调
* @param {Object} onComplete 请求完成(不管成功或失败)回调
* @param {Object} isVerify 是否验证重复提交
* @param {Object} requestType 请求类型(默认POST)
* @param {Object} retry 访问失败重新请求次数(默认1次)
*/
webCall: function (urlPath, params, requestCode, onSuccess, onErrorBefore, onComplete, isVerify, requestType, retry) {
var params = arguments[1] ? arguments[1] : {};
//var requestCode = arguments[2] ? arguments[2] : 1;
var onSuccess = arguments[3] ? arguments[3] : function () { };
var onErrorBefore = arguments[4] ? arguments[4] : this.onError;
var onComplete = arguments[5] ? arguments[5] : this.onComplete;
var isVerify = arguments[6] ? arguments[6] : false;
var requestType = arguments[7] ? arguments[7] : "POST";
var retry = arguments[8] ? arguments[8] : 1;
var that = this;
//防止重复提交,相同请求间隔时间不能小于500毫秒
var nowTime = new Date().getTime();
if (this.requestCount[urlPath] && (nowTime - this.requestCount[urlPath]) < 500) {
return;
}
this.requestCount[urlPath] = nowTime;
//是否验证重复提交
if (isVerify) {
if (this.verifyCount[urlPath]) {
return;
}
this.verifyCount[urlPath] = true; //重复验证开关开启
}
console.log("发起网络请求, 路径:" + (that.apiHost + urlPath) + ", 参数:" + JSON.stringify(params));
wx.request({
url: that.apiHost + urlPath,
data: params,
method: requestType, // OPTIONS, GET, HEAD, POST, PUT, DELETE, TRACE, CONNECT
header: {
'content-type': requestType == 'POST' ?
'application/x-www-form-urlencoded' : 'application/json'
}, // 设置请求的 header
success: function (res) {
console.log("返回结果:" + JSON.stringify(res.data));
if (res.data) {
if (res.data.statusCode == 200) { //访问成功
onSuccess(res.data, requestCode);
} else if (res.data.statusCode == 300000001) { // 未登录
that.isLogin = false;
onErrorBefore(0, res.data.message, requestCode);
} else {
onErrorBefore(0, res.data.message == null ? "请求失败 , 请重试" : res.data.message, requestCode);
}
} else {
onErrorBefore(0, "请求失败 , 请重试", requestCode);
}
},
fail: function (res) {
retry--;
console.log("网络访问失败:" + JSON.stringify(res));
if (retry > 0) return that.webCall(urlPath, params, requestCode, onSuccess, onErrorBefore, onComplete, requestType, retry);
},
complete: function (res) {
onComplete(requestCode);
//请求完成后,2秒后重复验证的开关关闭
if (isVerify) {
setTimeout(function () {
that.verifyCount[urlPath] = false;
}, 2000);
}
}
})
}
上面的verifyCount是放在data中的数组,apiHost 是放在js最外层的接口服务器地址,方便随时开发、测试环境。
这个方法也是必不可少的
complete: function (res) {
onComplete(requestCode);
//请求完成后,2秒后重复验证的开关关闭
if (isVerify) {
setTimeout(function () {
that.verifyCount[urlPath] = false;
}, 2000);
}
}
})
调用示范
请求:
// 请求 home banner 数据
wx.showNavigationBarLoading();
app.webCall("/app/homeBanner", {}, QUERY_BANNER, this.onSuccess, this.onErrorBefore, this.onComplete);
请求成功的回调处理:
/**
* 接口访问成功返回
* @param {Object} data
* @param {Object} requestCode
*/
onSuccess: function (data, requestCode) {
var that = this;
switch (requestCode) {
case QUERY_BANNER:
that.setData({ bannerData: (data ? data.data : []) });
break;
}
QUERY_BANNER是放在js最外层的常量,用于接口访问完成后的回调方法来区分请求的接口是哪个。
请求完成的处理:
/**
* 接口访问完成
* @param {Object} resultCode
*/
onComplete: function (resultCode) {
console.log("home onComplete1");
if (--mCurrentRequestNums <= 0) {
wx.hideNavigationBarLoading();
}
}
mCurrentRequestNums 是放在js最外层的变量,表示发起请求的数量,用于多个接口同时被调用,并希望在全部请求结束后关闭标题栏加载动画时用。
来源:https://blog.csdn.net/zhuyb829/article/details/72469641


猜你喜欢
- 前言最近在做项目高可用时,需要使用数据同步。由于只有双节点,且采用主主同步可能存在循环同步的风险,故综合考虑采用Mysql主从同步(Mast
- 一、优先级队列介绍我们知道,普通的队列插入一个元素,数据会被放在后端,并且需要前面所有的元素都处理完成后才会处理前面的数据。但是优先级队列,
- 简介查看百度搜索中文文本聚类我失望的发现,网上竟然没有一个完整的关于Python实现的中文文本聚类(乃至搜索关键词python 中文文本聚类
- 目录查找和修复数据表冲突更新索引统计查找和修复数据表冲突数据表最糟糕的事情就是发生冲突。使用MyISAM存储引擎时,通常因为崩溃导致冲突。然
- 问题:之前在学习list和dict相关的知识时,遇到了一个常见的问题:如何在遍历list或dict的时候正常删除?例如我们在遍历dict的时
- python内存管理机制:引用计数垃圾回收内存池1. 引用计数当一个python对象被引用时 其引用计数增加 1 ; 当其不再被变量引用时
- 判断字段是否存在:DROP PROCEDURE IF EXISTS schema_change; DELIMITER //CREATE PR
- 使用工具:pexpect库pexpect可以理解为Linux下expect(不知道的可以百度下linux expect)的python封装。
- 本文实例讲述了js实现遮罩层弹出框的方法。分享给大家供大家参考。具体分析如下:昨天公司网站需要弹窗提示一些信息,要我在把弹窗的js代码和弹窗
- 用字符串就可以轻松地获取每一个文件的名称和扩展名,但不要乱用:<%Function getFilename(text)tex
- 现在写一篇博客总是喜欢先谈需求或者本内容的应用场景,是的,如果写出来的东西没有任何应用价值,确实也没有实际意义。今天的最早的需求是来自于如何
- 以前在使用Python的时候,都是使用root用户安装好的全局python,现在,因为root用户安装的Python版本太低,同时自己没有r
- union all在MySQL5.6下的表现Part1:MySQL5.6.25[root@HE1 ~]# MySQL -uroot -pEn
- 本文首先介绍在python3中print函数的应用,然后对比在pyhton2中的应用。(本文作者所用版本为3.6.0)首先我们通过help(
- 一、实现双向绑定的做法前端MVVM最令人激动的就是双向绑定机制了,实现双向数据绑定的做法大致有如下三种:1.发布者-订阅者模式(backbo
- 本文实例为大家分享了python实现学生信息管理系统的具体代码,含代码注释、增删改查、排序、统计显示学生信息,供大家参考,具体内容如下运行如
- 1、 下载MYSQL5.1.48源码,CMAKE,VS2008 2、 安装CMAKE和VS2008,解压MYSQL5.1.48到D:\mys
- 单元测试长久以来是热门话题,本文不会讨论需不需要写单测,可以看看参考资料1,我个人认为写好单测应该是每个优秀开发者必备的技能,关于写单测
- 最近学到了一个有趣的装饰器写法,就记录一下。装饰器是一个返回函数的函数。写一个装饰器,除了最常见的在函数中定义函数以外,Python还允许使
- 背景接口域名没有写死,而是动态获取。具体实现就是 通过读取一个静态json文件,来设置真实的接口域名。好处是原域名有可能被封,这样可以直接后