微信小程序HTTP接口请求封装代码实例


Posted in Javascript onSeptember 05, 2019

1.方法封装(新建文件夹util,工具文件,在文件夹下创建request.js文件,用于对方法封装)

request.js:

var app = getApp();
//项目URL相同部分,减轻代码量,同时方便项目迁移
//这里因为我是本地调试,所以host不规范,实际上应该是你备案的域名信息
var host = 'http://localhost:8081/demo/';
 
/**
 * POST请求,
 * URL:接口
 * postData:参数,json类型
 * doSuccess:成功的回调函数
 * doFail:失败的回调函数
 */
function request(url, postData, doSuccess, doFail) {
 wx.request({
  //项目的真正接口,通过字符串拼接方式实现
  url: host + url,
  header: {
   "content-type": "application/json;charset=UTF-8"
  },
  data: postData,
  method: 'POST',
  success: function (res) {
   //参数值为res.data,直接将返回的数据传入
   doSuccess(res.data);
  },
  fail: function () {
   doFail();
  },
 })
}
 
//GET请求,不需传参,直接URL调用,
function getData(url, doSuccess, doFail) {
 wx.request({
  url: host + url,
  header: {
   "content-type": "application/json;charset=UTF-8"
  },
  method: 'GET',
  success: function (res) {
   doSuccess(res.data);
  },
  fail: function () {
   doFail();
  },
 })
}
/**
 * module.exports用来导出代码
 * js文件中通过var call = require("../util/request.js") 加载
 * 在引入引入文件的时候" "里面的内容通过../../../这种类型,小程序的编译器会自动提示,因为你可能
 * 项目目录不止一级,不同的js文件对应的工具类的位置不一样
 */
module.exports.request = request;
module.exports.getData = getData;

2.page里面随便一个创建一个文件夹,创建四种文件,在js里面加入 

//引入代码
var call = require("../util/request.js")
 
Page({
 data: {
  pictureList: [],
 },
  
 onLoad: function () {
  var that = this;
  //调用封装的方法,为了方便我直接在页面加载的时候执行这个方法
  call.getData('lunbo.do', this.shuffleSuc, this.fail);
  // 无用,前面忘记注释,抱歉
  // this.loadMsgData(that);
 },
 shuffleSuc: function (data) {
  var that = this;
  that.setData({
   pictureList: data.rows
  })
  //我后面测试了一下,直接this.setData也可以,但是因为我在没有使用封装方法的时候
  //this.setData报过错,不能直接用this,所以我在赋值的时候一般都会加上var that = this;
  //这句话算是一个不是习惯的习惯
 },
 fail: function () {
  console.log("失败")
 },
})

将回调函数写在page里面,在调用封装方法的时候通过this.方法名调用,这样就能确保that.setData方法有效,如果是写在外面的function方法小程序编译器不会报错,但是在wxml中bindtap无效,我也没深究,同时在call.getData方法中调用的时候虽然能够进入该方法,但是赋值是无效的,所以我不建议用这种方式:

function shuffleSuc(data) {
 var that = this;
 that.setData({
  pictureList: data.rows
 })
}

3. 运行之后通过小程序的控制台AppData可以打印data里面的值,同时也可以根据需要在页面中显示

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
extjs grid设置某列背景颜色和字体颜色的方法
Sep 03 Javascript
IE6/7 and IE8/9/10(IE7模式)依次隐藏具有absolute或relative的父元素和子元素后再显示父元素
Jul 31 Javascript
Javascript图像处理—虚拟边缘介绍及使用方法
Dec 27 Javascript
瀑布流布局代码一例
Apr 11 Javascript
javascript的日期对象、数组对象、二维数组使用说明
Dec 22 Javascript
js实现点击切换TAB标签实例
Aug 21 Javascript
多种jQuery绑定事件的实现方式
Jun 13 Javascript
jQuery实用小技巧_输入框文字获取和失去焦点的简单实例
Aug 25 Javascript
Node.js批量给图片加水印的方法
Nov 15 Javascript
解决easyui日期时间框ie的兼容的问题
Mar 01 Javascript
JS算法题之查找数字在数组中的索引位置
May 15 Javascript
学前端,css与javascript重难点浅析
Jun 11 Javascript
layui table去掉右侧滑动条的实现方法
Sep 05 #Javascript
微信小程序下拉加载和上拉刷新两种实现方法详解
Sep 05 #Javascript
layui动态加载多表头的实例
Sep 05 #Javascript
如何阻止小程序遮罩层下方图层滚动
Sep 05 #Javascript
layui多iframe页面控制定时器运行的方法
Sep 05 #Javascript
解决layer.msg 不居中 ifram中的问题
Sep 05 #Javascript
JS中比Switch...Case更优雅的多条件判断写法
Sep 05 #Javascript
You might like
php读取txt文件组成SQL并插入数据库的代码(原创自Zjmainstay)
2012/07/31 PHP
PHP网页游戏学习之Xnova(ogame)源码解读(十六)
2014/06/30 PHP
php获取url参数方法总结
2014/11/13 PHP
php使用file函数、fseek函数读取大文件效率对比分析
2016/11/04 PHP
PHP实现登陆表单提交CSRF及验证码
2017/01/24 PHP
php取出数组单个值的方法
2018/03/12 PHP
点击广告后才能获得下载地址
2006/10/26 Javascript
javascript 中对象的继承〔转贴〕
2007/01/22 Javascript
IE8 原生JSON支持
2009/04/13 Javascript
javascript 写类方式之十
2009/07/05 Javascript
jQuery 方法大全方便学习参考
2010/02/25 Javascript
JavaScript异步编程:异步数据收集的具体方法
2013/08/19 Javascript
node.js中的querystring.stringify方法使用说明
2014/12/10 Javascript
javascript实现控制浏览器全屏
2015/03/30 Javascript
javascript背景时钟实现方法
2015/06/18 Javascript
javascript实现加载xml文件的方法
2015/11/24 Javascript
基于jquery实现表格无刷新分页
2016/01/07 Javascript
bootstrap3 兼容IE8浏览器!
2016/05/02 Javascript
微信小程序开发(二)图片上传+服务端接收详解
2017/01/11 Javascript
php输出全部gb2312编码内的汉字方法
2017/03/04 Javascript
安装vue-cli报错 -4058 的解决方法
2017/10/19 Javascript
微信小程序scroll-view实现字幕滚动
2018/07/14 Javascript
使用vue-cli3新建一个项目并写好基本配置(推荐)
2019/04/24 Javascript
VScode格式化ESlint方法(最全最好用方法)
2019/09/10 Javascript
[04:40]2016国际邀请赛中国区预选赛全程TOP10镜头集锦
2016/07/01 DOTA
python脚本实现分析dns日志并对受访域名排行
2014/09/18 Python
Python装饰器用法实例总结
2018/05/26 Python
pandas.DataFrame选取/排除特定行的方法
2018/07/03 Python
在OpenCV里使用特征匹配和单映射变换的代码详解
2019/10/23 Python
Python可视化工具如何实现动态图表
2020/10/23 Python
音乐节策划方案
2014/06/09 职场文书
银行授权委托书样本
2014/10/13 职场文书
大学生毕业个人总结
2015/02/15 职场文书
党支部考察意见范文
2015/06/02 职场文书
导游词之云南-元阳梯田
2019/10/08 职场文书
利用Python判断整数是否是回文数的3种方法总结
2021/07/07 Python