這篇“微信小程序中的wx.request怎么用”文章的知識(shí)點(diǎn)大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細(xì),步驟清晰,具有一定的借鑒價(jià)值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“微信小程序中的wx.request怎么用”文章吧。
成都創(chuàng)新互聯(lián)公司從2013年成立,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目網(wǎng)站設(shè)計(jì)、成都網(wǎng)站建設(shè)網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個(gè)夢(mèng)想脫穎而出為使命,1280元長(zhǎng)子做網(wǎng)站,已為上家服務(wù),為長(zhǎng)子各地企業(yè)和個(gè)人服務(wù),聯(lián)系電話:18980820575
官方接口
官方給出的接口叫做wx.request,請(qǐng)求方式比較簡(jiǎn)單,下面是官網(wǎng)給出的請(qǐng)求實(shí)例。
wx.request({ url: 'test.php', //僅為示例,并非真實(shí)的接口地址 data: { x: '' , y: '' }, header: { 'content-type': 'application/json' }, success: function(res) { console.log(res.data) } })
存在的問題
wx.request請(qǐng)求的header中content-type默認(rèn)為application/json,如果我們想換種方式比如用"application/x-www-form-urlencoded"會(huì)發(fā)現(xiàn)在請(qǐng)求頭信息中并沒有取代默認(rèn)的application/json而是新增了這種方式,另外在用jquery.ajax請(qǐng)求時(shí)即便同樣使用application/json方式來請(qǐng)求,得到的數(shù)據(jù)格式也不相同,無論用什么請(qǐng)求方式ajax都會(huì)將請(qǐng)求數(shù)據(jù)轉(zhuǎn)換為&name1=value1&name2=value2的形式,這樣在根據(jù)content-type來解析請(qǐng)求數(shù)據(jù)時(shí)就會(huì)出現(xiàn)問題,不知道微信是有意這樣做還是它根本就是個(gè)bug??傊墙o我?guī)砹瞬槐匾穆闊?/p>
微信小程序發(fā)送的是https請(qǐng)求,在本地調(diào)試時(shí)可以用http,如果放在手機(jī)上測(cè)試時(shí)校驗(yàn)請(qǐng)求方式和域名,不合法會(huì)報(bào)以下錯(cuò)誤:
為了方便請(qǐng)求,可以對(duì)wx.request做一個(gè)簡(jiǎn)單的封裝,這樣我們?cè)僬{(diào)用的時(shí)候就方便了許多,代碼如下:
var app = getApp(); function request(url,postData,doSuccess,doFail,doComplete){ var host = getApp().conf.host; wx.request({ url: host+url, data:postData, method: 'POST', success: function(res){ if(typeof doSuccess == "function"){ doSuccess(res); } }, fail: function() { if(typeof doFail == "function"){ doFail(); } }, complete: function() { if(typeof doComplete == "function"){ doComplete(); } } }); } } module.exports.request = request;
如果一個(gè)接口在不同地方頻繁用到,原本設(shè)想寫一個(gè)函數(shù),然后將函數(shù)暴露供其他js調(diào)用,但后來發(fā)現(xiàn)wx.request中設(shè)置async是無效的,只能發(fā)異步請(qǐng)求,所以如果想寫一個(gè)函數(shù)來返回調(diào)用接口得到的數(shù)據(jù)就比較難實(shí)現(xiàn)。
以上就是關(guān)于“微信小程序中的wx.request怎么用”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對(duì)大家有幫助,若想了解更多相關(guān)的知識(shí)內(nèi)容,請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。