摘要:本文將帶你了解不同請求的原理,以及如何為項(xiàng)目選擇合適的請求庫。小程序年微信小程序上線,隨后各大平臺都推出自己的小程序。下面為目前較火的請求庫。支持微信小程序和瀏覽器是一個(gè)基于的請求庫,可以用在微信小程序和瀏覽器中,對上述平臺都做了兼容。
以前前端提到網(wǎng)絡(luò)請求通常是指瀏覽器,但現(xiàn)在隨著 Node.js、小程序的出現(xiàn),網(wǎng)絡(luò)請求不再局限于瀏覽器。本文將帶你了解不同請求的原理,以及如何為項(xiàng)目選擇合適的請求庫。1. 請求原理 1.1 瀏覽器
瀏覽器通過 XMLHttpRequest 對象實(shí)現(xiàn) http 請求。
遠(yuǎn)古時(shí)代 ie6 是借助 ActiveXObject 對象實(shí)現(xiàn) http 請求,目前已無人使用,不考慮兼容。
W3C 標(biāo)準(zhǔn)新提出的 Fecth API,基于 Promise 實(shí)現(xiàn),相對 XMLHttpRequest 對象調(diào)用更方便,但舊瀏覽器不支持 Promise,需要對 Promise 進(jìn)行 pollyfill。
XMLHttpRequest
let xhr = new XMLHttpRequest(); xhr.open("get", url, true); xhr.send(); xhr.onreadystatechange = function() { if(xhr.readyState === 4 && xhr.status === 200 ) { let response = JSON.parse(xhr.responseText); } }
Fetch
fetch(url) .then(response => response.json()) .then(data => console.log(data)) .catch(e => console.log("error", e))1.2 Node.js
Node.js 發(fā)布于 2009 年,是一個(gè)基于 Chrome V8 引擎的 JavaScript 運(yùn)行環(huán)境,Node.js 的頂層對象是 global,不存在 window 對象,不能通過 XMLHttpRequest 對象實(shí)現(xiàn) http 請求。
Node.js 中通過引入 http/https/http2 模塊實(shí)現(xiàn) http 請求,下面為 http 模塊實(shí)現(xiàn)的例子:
const http = require("http"); const server = http.createServer((req, res) => { res.end("hello world"); }); server.on("clientError", (err, socket) => { socket.end("HTTP/1.1 400 Bad Request "); }); server.listen(8000);1.3 React Native
React Native 是 Facebook 2015 開源跨平臺移動(dòng)應(yīng)用開發(fā)工具。
React Native 中已經(jīng)內(nèi)置了 XMLHttpRequest API,同時(shí)提供了和 web 標(biāo)準(zhǔn)一致的Fetch API,所以大部分在 web 端可以使用的網(wǎng)絡(luò)請求庫在 React Native 中也可以使用。
1.4 WeexWeex 是 阿里 2016 開源跨平臺移動(dòng)應(yīng)用開發(fā)工具。
Weex 通過封裝模塊來調(diào)用原生功能,提供了 stream 模塊來實(shí)現(xiàn)網(wǎng)絡(luò)請求。
1.5 小程序2017 年微信小程序上線,隨后各大平臺都推出自己的小程序。
小程序由于要對 http 請求做參數(shù)校驗(yàn)、兼容各平臺(iOS、Android)或版本問題,所以提供了一套屬于自己的 API,不提供 window 對象。
下面為微信小程序和支付寶小程序的官網(wǎng)示例:
微信小程序
wx.request({ url: "test.php", // 僅為示例,并非真實(shí)的接口地址 data: { x: "", y: "" }, header: { "content-type": "application/json" // 默認(rèn)值 }, success(res) { console.log(res.data) } })
支付寶小程序
my.httpRequest({ url: "http://httpbin.org/post", method: "POST", data: { from: "支付寶", production: "AlipayJSAPI", }, dataType: "json", success: function(res) { my.alert({content: "success"}); }, fail: function(res) { my.alert({content: "fail"}); }, complete: function(res) { my.hideLoading(); my.alert({content: "complete"}); } });2. 請求庫
從上文可以看出,平臺間的請求方式存在各種差異,請求庫就是為解決這種差異。下面為目前較火的請求庫。
2.1 $.ajax(支持瀏覽器)$.ajax 為 jQuery 對 XMLHttpRequest 對象進(jìn)行兼容封裝。
需要補(bǔ)充的是 React Native 可以使用部分瀏覽器網(wǎng)絡(luò)請求庫,但是不能使用 jQuery,因?yàn)?jQuery 中還使用了很多瀏覽器中才有而 React Native 中沒有的東西。
此外,現(xiàn)在使用框架的項(xiàng)目中我們通常采用其他請求庫,或者自己根據(jù)項(xiàng)目對 XMLHttpRequest 或 Fetch 進(jìn)行封裝,不會(huì)為了網(wǎng)絡(luò)請求引入 jQuery。
2.2 Request(支持 Node.js)Request 是對 Node.js 的 http/https 模塊封裝的 http 庫。
var request = require("request"); request("http://www.google.com", function (error, response, body) { console.log("error:", error); // Print the error if one occurred console.log("statusCode:", response && response.statusCode); // Print the response status code if a response was received console.log("body:", body); // Print the HTML for the Google homepage. });2.3 SuperAgent(支持 Node.js)
SuperAgent 和 Request 類似,都是對 Node.js 的 http/https 模塊封裝的 http 庫。
var request = require("superagent") request .post("/api/pet") .send({ name: "Manny", species: "cat" }) .set("X-API-Key", "foobar") .set("Accept", "application/json") .then(res => { alert("yay got " + JSON.stringify(res.body)); });2.4 Axios(支持 React Native,Node,瀏覽器)
Axios 是一個(gè)基于 promise 的 HTTP 請求庫,可以用在瀏覽器和 Node.js 中。瀏覽器中使用 XMLHttpRequest,Node.js 中使用 http/https 模塊。下面為請求示例:
axios.get("/user?ID=12345") .then(function (response) { console.log(response); }) .catch(function (error) { console.log(error); });
Vue 2.0 推薦使用 Axios 作為 Vue 的請求庫。而且在 SSR 的時(shí)候我們在服務(wù)端、客戶端都需要請求,所以通常會(huì)選擇 Axios。
2.5 Fly.js(支持 Node.js 、微信小程序 、Weex 、React Native 、Quick App 和瀏覽器)Fly.js 是一個(gè)基于 promise 的 HTTP 請求庫,可以用在Node.js 、微信小程序 、Weex 、React Native 、Quick App 和瀏覽器中,對上述平臺都做了兼容。
fly.get("/user?id=133") .then(function (response) { console.log(response); }) .catch(function (error) { console.log(error); });
除了 Fly.js,有些小程序開發(fā)框架本身提供網(wǎng)絡(luò)請求庫,對平臺做了兼容,比如 Taro.request。
3. 總結(jié)不同請求庫之間的 API、使用都會(huì)存在區(qū)別。項(xiàng)目開始時(shí),根據(jù)需要兼容的平臺選擇合適的請求庫,會(huì)大大減少以后代碼重構(gòu)的麻煩。
本文首發(fā)于公眾號,更多內(nèi)容歡迎關(guān)注我的公眾號: 阿夸漫談
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/108900.html
摘要:具體來說,包管理器就是可以通過命令行,幫助你把外部庫和插件放到你的項(xiàng)目里面并在之后進(jìn)行版本升級,這樣就不用手工復(fù)制和更新庫?,F(xiàn)在有的包管理器主要是和。 一、基礎(chǔ) 1、學(xué)習(xí)HTML基礎(chǔ) HTML給你的網(wǎng)頁賦予了結(jié)構(gòu)。它就像是人的骨架那樣讓你保持站立。首先你需要去學(xué)習(xí)語法以及它必須提供的一切。你的學(xué)習(xí)應(yīng)該聚焦在下面這些東西上: 學(xué)習(xí)HTML基礎(chǔ),了解如何編寫語義HTML 理解如何把網(wǎng)頁分...
摘要:具體來說,包管理器就是可以通過命令行,幫助你把外部庫和插件放到你的項(xiàng)目里面并在之后進(jìn)行版本升級,這樣就不用手工復(fù)制和更新庫?,F(xiàn)在有的包管理器主要是和。 一、基礎(chǔ) 1、學(xué)習(xí)HTML基礎(chǔ) HTML給你的網(wǎng)頁賦予了結(jié)構(gòu)。它就像是人的骨架那樣讓你保持站立。首先你需要去學(xué)習(xí)語法以及它必須提供的一切。你的學(xué)習(xí)應(yīng)該聚焦在下面這些東西上: 學(xué)習(xí)HTML基礎(chǔ),了解如何編寫語義HTML 理解如何把網(wǎng)頁分...
摘要:讓你收獲滿滿碼個(gè)蛋從年月日推送第篇文章一年過去了已累積推文近篇文章,本文為年度精選,共計(jì)篇,按照類別整理便于讀者主題閱讀。本篇文章是今年的最后一篇技術(shù)文章,為了讓大家在家也能好好學(xué)習(xí),特此花了幾個(gè)小時(shí)整理了這些文章。 showImg(https://segmentfault.com/img/remote/1460000013241596); 讓你收獲滿滿! 碼個(gè)蛋從2017年02月20...
摘要:周末是時(shí)隔兩月的家人團(tuán)聚,而每次內(nèi)容的準(zhǔn)備平均需要我集中精力工作小時(shí),所以第期的內(nèi)容今早才準(zhǔn)備好,對不住大家了。下面是本周精選內(nèi)容,請享用。本文作者王仕軍,商業(yè)轉(zhuǎn)載請聯(lián)系作者獲得授權(quán),非商業(yè)轉(zhuǎn)載請注明出處。 showImg(https://segmentfault.com/img/remote/1460000009742537?w=1240&h=509); 周末是時(shí)隔兩月的家人團(tuán)聚,而...
閱讀 1113·2021-11-23 09:51
閱讀 1080·2021-10-18 13:31
閱讀 2978·2021-09-22 16:06
閱讀 4272·2021-09-10 11:19
閱讀 2204·2019-08-29 17:04
閱讀 431·2019-08-29 10:55
閱讀 2482·2019-08-26 16:37
閱讀 3379·2019-08-26 13:29