封裝微信小程序http攔截器過(guò)程解析
前言
微信小程序是數(shù)據(jù)驅(qū)動(dòng)的應(yīng)用,開(kāi)發(fā)技術(shù)和vue、react和angular等mv*技術(shù)類似。在vue下可以用vue-resource、axios等模塊進(jìn)行http請(qǐng)求,但是在微信小程序上,http請(qǐng)求只支持wx.request(OBJECT),所以我們需要對(duì)wx.request進(jìn)行封裝,實(shí)現(xiàn)http攔截器的功能。
第一步:創(chuàng)建一個(gè)request.js文件
第二步:確定http、upload和websocket前綴
第三步:封裝wx.request
在請(qǐng)求發(fā)出前處理http地址、請(qǐng)求頭和參數(shù)、在響應(yīng)后解析返回值并做基本的邏輯判斷,重點(diǎn)是使用Promise對(duì)象。
第四步:導(dǎo)出模塊
第五步:使用request
const Request = require("/utils/request");//導(dǎo)入模塊 Request.post("/api/xcxWxLogin", { //調(diào)用方法 code: res.code, encryptedData: resp.encryptedData, iv: resp.iv, shareId: share.shareId || "", salesmanId: share.salesmanId || "", source: share.source || "" }).then(res => { //成功回調(diào) //todo }).catch(err => {}); //異?;卣{(diào)
第六步:攔截器完整代碼
const apiHttp = "https://*****.com"; const socketHttp = "wss://*****.com/wss"; function fun(url, method, data, header) { data = data || {}; header = header || {}; let sessionId = wx.getStorageSync("UserSessionId"); if (sessionId) { if (!header || !header["SESSIONID"]) { header["SESSIONID"] = sessionId; } } wx.showNavigationBarLoading(); let promise = new Promise(function(resolve, reject) { wx.request({ url: apiHttp + url, header: header, data: data, method: method, success: function(res) { if (typeof res.data === "object") { if (res.data.status) { if (res.data.status === -200) { wx.showToast({ title: "為確保能向您提供最準(zhǔn)確的服務(wù),請(qǐng)退出應(yīng)用重新授權(quán)", icon: "none" }); reject("請(qǐng)重新登錄"); } else if (res.data.status === -201) { wx.showToast({ title: res.data.msg, icon: "none" }); setTimeout(function() { wx.navigateTo({ url: "/pages/user/supplement/supplement" }); }, 1000); reject(res.data.msg); } } } resolve(res); }, fail: reject, complete: function() { wx.hideNavigationBarLoading(); } }); }); return promise; } function upload(url, name, filePath) { let header = {}; let sessionId = wx.getStorageSync("UserSessionId"); //從緩存中拿該信息 if (sessionId) { if (!header || !header["SESSIONID"]) { header["SESSIONID"] = sessionId; //添加到請(qǐng)求頭中 } } wx.showNavigationBarLoading(); let promise = new Promise(function(resolve, reject) { wx.uploadFile({ url: apiHttp + url, filePath: filePath, name: name, header: header, success: function(res) { resolve(res); }, fail: reject, complete: function() { wx.hideNavigationBarLoading(); } }); }); return promise; } module.exports = { apiHttp: apiHttp, socketHttp: socketHttp, "get": function(url, data, header) { return fun(url, "GET", data, header); }, "post": function(url, data, header) { return fun(url, "POST", data, header); }, upload: function(url, name, filePath) { return upload(url, name, filePath); } };
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JS實(shí)現(xiàn)點(diǎn)擊文字對(duì)應(yīng)DIV層不停閃動(dòng)效果的方法
這篇文章主要介紹了JS實(shí)現(xiàn)點(diǎn)擊文字對(duì)應(yīng)DIV層不停閃動(dòng)效果的方法,實(shí)例分析了javascript操作div層的效果,非常實(shí)用,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03通過(guò)JS和PHP兩種方法判斷用戶請(qǐng)求時(shí)使用的瀏覽器類型
在做微站點(diǎn)項(xiàng)目開(kāi)發(fā)的時(shí)候,我們需要判斷當(dāng)前瀏覽器類型是什么。接下來(lái)小編給大家分享通過(guò)JS和PHP兩種方法判斷用戶請(qǐng)求時(shí)使用的瀏覽器類型,非常不錯(cuò),感興趣的朋友一起學(xué)習(xí)吧2016-09-09JavaScript使用prototype屬性實(shí)現(xiàn)繼承操作示例
這篇文章主要介紹了JavaScript使用prototype屬性實(shí)現(xiàn)繼承操作,結(jié)合實(shí)例形式詳細(xì)分析了JavaScript使用prototype屬性實(shí)現(xiàn)繼承的相關(guān)原理、實(shí)現(xiàn)方法與操作注意事項(xiàng),需要的朋友可以參考下2020-05-05使用原生JavaScript實(shí)現(xiàn)放大鏡效果
這篇文章主要為大家詳細(xì)介紹了如何使用原生JavaScript實(shí)現(xiàn)放大鏡效果(可自由大小適配),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2023-03-03JavaScript實(shí)現(xiàn)頁(yè)面無(wú)操作倒計(jì)時(shí)退出
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)頁(yè)面無(wú)操作倒計(jì)時(shí)退出,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-10-10chrome瀏覽器當(dāng)表單自動(dòng)填充時(shí)如何去除瀏覽器自動(dòng)添加的默認(rèn)樣式
很多朋友都遇到這個(gè)問(wèn)題:當(dāng)使用chrome瀏覽器表單自動(dòng)填充時(shí)都會(huì)自動(dòng)添加默認(rèn)的樣式,該如何去除默認(rèn)樣式呢?看看小編是怎么去除的,需要的朋友一起學(xué)習(xí)吧2015-10-10移動(dòng)端刮刮樂(lè)的實(shí)現(xiàn)方式(js+HTML5)
本篇文章主要介紹了移動(dòng)端刮刮樂(lè)的實(shí)現(xiàn)方法以及實(shí)現(xiàn)代碼。具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧2017-03-03淺談JavaScript 函數(shù)參數(shù)傳遞到底是值傳遞還是引用傳遞
下面小編就為大家?guī)?lái)一篇淺談JavaScript 函數(shù)參數(shù)傳遞到底是值傳遞還是引用傳遞。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-08-08