Recently, I have made two small programs, with relatively simple business and a lot of harvest in terms of public welfare. I feel that the encapsulation of Request has significantly improved the development efficiency and reduced the amount of code in the development. Here is a brief summary.
General packaging
Create two new files in the utils folder, config.js and request.js, with the following code respectively.
Module. exports = {appID: "wxcXXXXXXXXXXXXXX349f", API_BASE_URL: 'https://liugezhou.github.io/', / / a temporary address, online test environment need to modify the} ` request ` - request packaging const CONFIG = the require (". / CONFIG. Js ") const request = (url,method,data) => { let _url = CONFIG.API_BASE_URL+url return new Promise((resolve ,reject)=>{ wx.request({ url: _url, method:method, data:data, header: { 'content-type': 'application/json' // default}, success(request) {resolve(request.data)}, fail(error) {reject(error)}, Complete (aaa) {// load done}})})} /** * Applet promise has no finally method, His extension under * / Promise. Prototype. Finally = function (the callback) {var Promise = this. Constructor; return this.then( function (value) { Promise.resolve(callback()).then( function () { return value; }); }, function (reason) { Promise.resolve(callback()).then( function () { throw reason; }); }); Module.exports = {request,} // All interface definitions are here. Return request('WeChat/ login. aspx','POST',data)}, // Obtain the verification code. (mobile) => { return request('Donor/DonorPhoneCode.aspx? '+ mobile,' POST ')},... }Copy the code
With the above two small files we have wrapped up the request. When calling the code in the business layer, we just need:
const REQUEST = require('.. /.. /utils/request.js'); .................................................................................... var that =this REQUEST.login({ tokenkey: res.code }).then(function(res){ that.globalData.openId = res.data.tokenkey that.globalData.isBind = res.code }). Catch (res => {// Catch fail here console.log('fail:',res); }). The finally (() = > {/ / finally console. Here the log (' finally: ", "end"); })........................................................................Copy the code
Queue encapsulation (not commonly used)
Under normal circumstances, the above packaging we according to their own needs slightly modified should be easy to use. The next one is interface queueing encapsulation. Because in our development requirements, each interface request requires two pieces of data returned by the previous interface, we rearrange them as follows:
//request.js const CONFIG = require("./config.js") let requestlist = []; let doing = false; const request = (link, data, back) => { var link = CONFIG.API_BASE_URL + link requestlist.push({ link: link, data: data, back: back }) if (! doing) dorequest(); } const dorequest = () => { doing = true let task = requestlist.shift(); if (task) { wx.request({ url: task.link, data: Object.assign({ seq : wx.getStorageSync("seq") || '', token : wx.getStorageSync("token") || '', openid : wx.getStorageSync("openId") || ''}, task.data), method: 'POST', header: {'content-type': 'application/json' // default}, success: res => { wx.setStorageSync("seq", res.data.seq) wx.setStorageSync("token", res.data.token) task.back(res.data); dorequest(); }, fail:function(){wx.showtoast ({title: 'server failed ', image: '.. /.. /assets/icon/wrong.png', duration: 3000 }) }, complete:function(){ } }); } else { doing = false; }}; Module. exports = {request, // get user openId getOpenid: (data,res) => {return request(' get-wx-openID ',data,res)}, (data,res) => { return request('send-phone-code', data, res) } }Copy the code