溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

利用JavaScript怎么發(fā)送一個(gè)HTTP請(qǐng)求

發(fā)布時(shí)間:2021-01-06 16:26:03 來(lái)源:億速云 閱讀:342 作者:Leah 欄目:web開(kāi)發(fā)

這篇文章給大家介紹利用JavaScript怎么發(fā)送一個(gè)HTTP請(qǐng)求,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對(duì)大家能有所幫助。

Ajax

Ajax是發(fā)出異步HTTP請(qǐng)求的傳統(tǒng)方式??梢允褂肏TTP POST方法發(fā)送數(shù)據(jù),并使用HTTP GET方法接收數(shù)據(jù)。我們來(lái)看看發(fā)送GET請(qǐng)求。我將使用JSONPlaceholder,這是一個(gè)免費(fèi)的在線(xiàn)REST API,適用于以JSON格式返回隨機(jī)數(shù)據(jù)的開(kāi)發(fā)人員。 要在Ajax中進(jìn)行HTTP調(diào)用,您需要初始化一個(gè)新XMLHttpRequest()方法,指定URL端點(diǎn)和HTTP方法(在本例中為GET)。最后,我們使用該open()方法將HTTP方法和URL端點(diǎn)綁定在一起,并調(diào)用該send()方法來(lái)觸發(fā)請(qǐng)求。 我們使用XMLHTTPRequest.onreadystatechange包含要在readystatechanged事件觸發(fā)時(shí)調(diào)用的事件處理程序的屬性將HTTP響應(yīng)記錄到控制臺(tái)。

利用JavaScript怎么發(fā)送一個(gè)HTTP請(qǐng)求 

如果您查看瀏覽器控制臺(tái),它將返回JSON格式的數(shù)據(jù)數(shù)組。但是我們?cè)趺粗勒?qǐng)求是否完成了?換句話(huà)說(shuō),我們?nèi)绾问褂肁jax處理響應(yīng)? 該onreadystatechange有兩個(gè)方法,readyState 和 status允許我們可以檢查請(qǐng)求的狀態(tài)。

利用JavaScript怎么發(fā)送一個(gè)HTTP請(qǐng)求 

如果readyState等于4,則表示請(qǐng)求已完成。 除了使用JavaScript直接進(jìn)行Ajax調(diào)用之外,還有其他更強(qiáng)大的HTTP調(diào)用方法,例如$.AjaxjQuery方法。

jQuery方法 jQuery有很多方法可以輕松處理HTTP請(qǐng)求。要使用這些方法,您需要在項(xiàng)目中包含jQuery庫(kù)。

$.ajax

jQuery Ajax是進(jìn)行HTTP調(diào)用的最簡(jiǎn)單方法之一。

利用JavaScript怎么發(fā)送一個(gè)HTTP請(qǐng)求 

$ .ajax方法需要許多參數(shù),其中一些是必需的,另一些是可選的。它包含兩個(gè)回調(diào)選項(xiàng)success并error處理收到的響應(yīng)。

$.get方法

$.get方法用于執(zhí)行GET請(qǐng)求。它需要兩個(gè)參數(shù):請(qǐng)求地址和回調(diào)函數(shù)。

利用JavaScript怎么發(fā)送一個(gè)HTTP請(qǐng)求 

$.post

該$.post方法是將數(shù)據(jù)發(fā)布到服務(wù)器的另一種方法。它需要三個(gè)參數(shù):請(qǐng)求的url地址您要發(fā)送的數(shù)據(jù)和回調(diào)函數(shù)。

利用JavaScript怎么發(fā)送一個(gè)HTTP請(qǐng)求 

$.getJson

該$.getJSON方法僅檢索JSON格式的數(shù)據(jù)。它需要兩個(gè)參數(shù):url和回調(diào)函數(shù)。

利用JavaScript怎么發(fā)送一個(gè)HTTP請(qǐng)求 

jQuery具有所有這些方法來(lái)請(qǐng)求或?qū)?shù)據(jù)發(fā)布到遠(yuǎn)程服務(wù)器。但實(shí)際上你可以將所有這些方法合而為一:$.ajax方法,如下例所示:

利用JavaScript怎么發(fā)送一個(gè)HTTP請(qǐng)求 

Fetch

fetch是一個(gè)新的功能強(qiáng)大的Web API,可以讓您發(fā)出異步請(qǐng)求。事實(shí)上,這fetch是制作HTTP請(qǐng)求的最佳和最喜歡的方式之一。它返回一個(gè)“Promise”,這是ES6的一大特色。 如果你不熟悉ES6,你可以閱讀一下關(guān)于ES6的文章。Promise允許我們以更智能的方式處理異步請(qǐng)求。我們來(lái)看看fetch技術(shù)如何運(yùn)作。

利用JavaScript怎么發(fā)送一個(gè)HTTP請(qǐng)求 

該fetch函數(shù)需要一個(gè)必需參數(shù):endpointURL。它還有其他可選參數(shù),如下例所示:

利用JavaScript怎么發(fā)送一個(gè)HTTP請(qǐng)求 

如您所見(jiàn),fetch制作HTTP請(qǐng)求有許多優(yōu)點(diǎn)。此外,在fetch中還有其他模塊和插件,允許我們向服務(wù)器端發(fā)送和從服務(wù)器端接收請(qǐng)求,例如Axios.

Axios

Axios是一個(gè)用于發(fā)出HTTP請(qǐng)求的開(kāi)源庫(kù),并提供許多強(qiáng)大的功能。我們來(lái)看看它是如何工作的。

用法: 首先,您需要包含Axios。有兩種方法可以在項(xiàng)目中包含Axios。 首先,你可以使用npm: npm install axios --save

然后你需要導(dǎo)入它 import axios from 'axios'

使用axios發(fā)出請(qǐng)求: 使用Axios,您可以使用GET和POST從服務(wù)器檢索和發(fā)布數(shù)據(jù)。

利用JavaScript怎么發(fā)送一個(gè)HTTP請(qǐng)求 

axios采用一個(gè)必需參數(shù),也可以采用第二個(gè)可選參數(shù)。這將一些數(shù)據(jù)作為簡(jiǎn)單查詢(xún)。

POST:

利用JavaScript怎么發(fā)送一個(gè)HTTP請(qǐng)求 

Axios返回“Promise”。如果您熟悉promises,您可能知道promise可以執(zhí)行多個(gè)請(qǐng)求。您可以使用axios執(zhí)行相同的操作并同時(shí)運(yùn)行多個(gè)請(qǐng)求。

關(guān)于利用JavaScript怎么發(fā)送一個(gè)HTTP請(qǐng)求就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI