1,封装请求方法
1.方法封装(新建文件夹utils,工具文件,在文件夹下创建http.js文件,用于对方法封装)
http.js:
var app = getApp(); //项目URL相同部分,减轻代码量,同时方便项目迁移 var host = 'https://xxx.com/'; /** * 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.postData = request; module.exports.getData = getData;
2,调用
//引入代码 var http = require("../../../utils/http.js") //Page({.. //调用方法 http.getData('api/v1/common/basic/query/setting.htm', (data) => { var that = this; console.log(data) // that.setData({ // pictureList: data.rows // }) //我后面测试了一下,直接this.setData也可以,但是因为我在没有使用封装方法的时候 //this.setData报过错,不能直接用this,所以我在赋值的时候一般都会加上var that = this; //这句话算是一个不是习惯的习惯 }, (data)=>{ console.log(data) });