时间:2021-05-18
本文实例讲述了微信小程序封装的HTTP请求。分享给大家供大家参考,具体如下:
微信小程序里自己封装了请求的函数,但几乎每个页面都要用到,所以为什么更方便的调用,再一次进行封装。
在app.js里面定义个全局对象,这样想要用到该函数,只需要在该页面的js文件里面,请求一个app实例。
废话不多说,先上代码:
//全局对象httpClienthttpClient:{ request:function(method,url,data){ //返回一个promise实例 return new Promise( (resolve,reject)=>{ wx.request({ url:url, data:data, mehtod:method, success:function(res){ resolve(res) }, fail:function(res){ reject(res); }, complete:function(){ console.log('complete'); } }) }) } //get方法:用来获取数据 get:function( url ) { return this.request('GET',url); }, //post方法:用来更新数据 post:function( url,data) { resturn this.request('POST',url,data); }, //put方法 put:function(url,data){ return this.request('PUT', url, data); }, //delete方法 delete:function(url,data){ return this.request('DELETE', url, data); }在需要请求的页面调用:
例如:登录页面login.js
//获取app实例,从而调用全局对象的函数var app=getApp();login:function(){ var url='http:xxxxx/login'; var data={ userName:'xxxxx', passwd:'xxxxxx' } app.httpClient.post( url,data ) .then( res=>{console.log("请求成功时调用该函数")}) .catch(res=>{console.log("请求失败时调用该函数")})}//为了更好的阅读,也可以将回调函数,定义在外面//这样loginSuccess:function(){ console.log("请求成功时调用该函数")},loginFail:function(){ console.log("请求失败时调用该函数")},login:function(){ var self=this; var url='http:xxxxx/login'; var data={ userName:'xxxxx', passwd:'xxxxxx' } app.httpClient.post( url,data ) .then( res=>self.loginSuccess()) .catch(res=>self.loginFail())}是不是简洁多了。。。。
附:升级版
上代码
// 该函数怎么写,需要跟后端人员协商返回的格式function getErrorMsgByErrorNo(error_no) { let error_msg; switch (error_no) { case 100: error_msg = '操作失败,请稍后再试!'; break; default: error_msg = '网络错误,请稍后再试!'; break; } return error_msg;}function handleData(res) { if (res.data.success) { if (typeof (res.data.body) === 'string') { return []; } else if (Array.isArray(res.data.body) === false) { const _arr = []; _arr.push(res.data.body); return _arr; } else { return res.data.body; } } else { if (res.data.error_no) { return { error_no: res.data.error_no, error_msg: getErrorMsgByErrorNo(res.data.error_no) }; } else { return { error_no: 123456, error_msg: '服务器维护中,请稍后!' }; } }}const httpClient = { request: function (method, url, data) { return new Promise((resolve, reject) => { wx.request({ url: url, data: data, method: method, success: function (res) { resolve(handleData(res)) }, fail: function (err) { console.log('request fail ', err); resolve({ error_no: 100, error_msg: getErrorMsgByErrorNo(100) }) }, complete: function (res) { console.log("request completed!"); } }) }); }, get: function (url) { return this.request('GET', url); }, post: function (url, data) { return this.request('POST', url, data); }, put: function (url, data) { return this.request('PUT', url, data); }, delete: function (url, data) { return this.request('DELETE', url, data); },};module.exports = httpClient;使用
function getMyselfData() { const _Url= urls.url; return httpClient.get(_Url);} getData() { let resultsData = this.getMyselfData(); resultsData.then((res) => { if (res.error_no) { // 只要有error_no就说明请求出现了错误 this.toast.showToast({ type: 'fail', title: res.error_msg, }) } else { this.setData({ journeyList: res.data }) } }); },希望本文所述对大家微信小程序开发有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
微信小程序之网络请求简单封装实例详解在微信小程序中实现网络请求相对于Android来说感觉简单很多,我们只需要使用其提供的API就可以解决网络请求问题。普通HT
微信升级版本后可以退回去吗?微信怎么升级版本?微信总是会时常的更新一些功能,只有微信升级版本才可以使用这些新的功能,如果微信升级版本后可以退回去吗?相信有很
这篇文章主要介绍了微信小程序request请求封装,验签代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考
本文实例讲述了微信小程序设置全局请求URL及封装wx.request请求操作。分享给大家供大家参考,具体如下:app.js:App({//设置全局请求URLgl
淘宝分享+升级版上线!淘宝分享+升级版怎么用?淘宝官方宣布淘宝分享+升级版上线!下面装修宅小编为大家介绍一下淘宝分享+升级版。 分享+升级版将于2017年