前端常用的幾種請求方式(Ajax,fetch,xmlHttpRequest)

XMLHttpRequest

var xmlhttp = new XMLHttpRequest();

xmlhttp.onreadystatechange=function()

? ?{

? ? ? ? ? if (xmlhttp.readyState==4 && xmlhttp.status==200) {

? ? ? ? ? ? ? ? ?document.getElementById("myDiv").innerHTML=xmlhttp.responseText;?

? ? ? ? ? ? }

? ? ?}

xmlhttp.open("GET","test1.txt",true);

xmlhttp.send();

以上為一個請求的基本形式

如需將請求發(fā)送到服務(wù)器,我們使用 XMLHttpRequest 對象的 open() 和 send() 方法

如需獲得來自服務(wù)器的響應(yīng),請使用 XMLHttpRequest 對象的 responseText 或 responseXML 屬性。

當請求被發(fā)送到服務(wù)器時,我們需要執(zhí)行一些基于響應(yīng)的任務(wù)。每當 readyState 改變時,就會觸發(fā) onreadystatechange 事件。

readyState 屬性存有 XMLHttpRequest 的狀態(tài)信息。


XMLHttpRequest 對象的三個重要的屬性

此外,如果需要像 HTML 表單那樣 POST 數(shù)據(jù),請使用 setRequestHeader() 來添加 HTTP 頭。然后在 send() 方法中規(guī)定您希望發(fā)送的數(shù)據(jù)

xmlhttp.open("POST","ajax_test.asp",true);

xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");

xmlhttp.send("fname=Bill&lname=Gates");



jQuery ajax

jQuery 的 ajax 是對 XMLHttpRequest的封裝,它的用法一般有這幾種:

1 )$.ajax

$.ajax({

? ? ? ? url:URL,

? ? ? ? type:'GET',

? ? ? ? dataType:"json",?

? ? ? ? success : function(data) { }

? ? ? ? error :function(er){ }

});

2 ) $.get ()

$(selector).get(url,data,success(response,status,xhr),dataType)

$.get()參數(shù)詳解


3 ) $.post()

jQuery.post(url,data,success(data, textStatus, jqXHR),dataType)


$.post()參數(shù)詳解


最后,目前前端用的最多的Fetch

Fetch API

fetch(URL).then(function(response){

? ? return response.json();

}).then(function(json){

insertPhotos(json);

});





ps:

POST和GET的選擇與區(qū)別


by.潘小閑

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • AJAX 原生js操作ajax 1.創(chuàng)建XMLHttpRequest對象 var xhr = new XMLHtt...
    碧玉含香閱讀 3,556評論 0 7
  • 本文詳細介紹了 XMLHttpRequest 相關(guān)知識,涉及內(nèi)容: AJAX、XMLHTTP、XMLHttpReq...
    semlinker閱讀 13,990評論 2 18
  • 大家好,我是IT修真院深圳分院第3期的學員,一枚正直純潔善良的前端程序員,今天給大家分享一下,修真院官網(wǎng)前端工程師...
    大大頭大閱讀 8,077評論 1 72
  • ajax是什么: ajax簡單的說就是做數(shù)據(jù)交互使用的。 Ajax的原理簡單來說通過XmlHttpRequest對...
    liudai123閱讀 455評論 0 0
  • 什么是Ajax 不刷新頁面的情況下從服務(wù)器獲取、提交數(shù)據(jù)的一種數(shù)據(jù)交互方式。 Ajax使用步驟 1\創(chuàng)建Ajax對...
    LaBaby_閱讀 330評論 0 0

友情鏈接更多精彩內(nèi)容