摘要:包括對象的本質(zhì),請求和響應(yīng)。下例為小張發(fā)送給大元的便條,存儲(chǔ)為。表的值常量值含義尚未調(diào)用已經(jīng)調(diào)用接收到頭信息接收到響應(yīng)主體響應(yīng)完成為了監(jiān)聽事件,請把事件處理函數(shù)設(shè)置為對象的屬性。響應(yīng)包狀態(tài)碼,響應(yīng)頭和響應(yīng)主體。
前言
博主博客:Stillwater的博客
知乎專欄:前端汪汪
本文為作者原創(chuàng)轉(zhuǎn)載請注明出處:
http://hiztx.top/2017/01/13/a...
??這篇文章介紹了XMLHttpRequest對象相關(guān)知識(shí)。包括:XMLHttpRequest對象的本質(zhì),Http請求和Http響應(yīng)。
一、XMLHttpRequest對象的本質(zhì)??為了更好的理解XMLHttpRequest對象的本質(zhì),我們將其分成三部分來理解。顧名思義,
什么是XML?XMLHttpRequest = XML + Http + Request 。
??XML設(shè)計(jì)用來傳送及攜帶數(shù)據(jù)信息,不用來表現(xiàn)或展示數(shù)據(jù),HTML語言則用來表現(xiàn)數(shù)據(jù),所以XML用途的焦點(diǎn)是它說明數(shù)據(jù)是什么,以及攜帶數(shù)據(jù)信息。XML被廣泛用來作為跨平臺(tái)之間交互數(shù)據(jù)的形式,主要針對數(shù)據(jù)的內(nèi)容。
??例如,XML定義結(jié)構(gòu)、存儲(chǔ)信息、傳送信息。下例為小張發(fā)送給大元的便條,存儲(chǔ)為XML。這XML文檔僅是純粹的信息標(biāo)簽,這些標(biāo)簽意義的展開依賴于應(yīng)用它的程序。
<小紙條> <收件人>大元收件人> <發(fā)件人>小張發(fā)件人> <主題>問候主題> <具體內(nèi)容>早啊,飯吃了沒? 具體內(nèi)容> 小紙條>什么是Http?
??超文本傳輸協(xié)議(英文:HyperText Transfer Protocol,縮寫:HTTP)是互聯(lián)網(wǎng)上應(yīng)用最為廣泛的一種網(wǎng)絡(luò)協(xié)議。設(shè)計(jì)HTTP最初的目的是為了提供一種發(fā)布和接收HTML頁面的方法。本文后面會(huì)詳細(xì)介紹AJAX技術(shù)相關(guān)的Http知識(shí)。
什么是Request???Request翻譯為請求,這個(gè)大家都知道。但是很多人會(huì)誤解,只有用瀏覽器(Chrome,Safari,IE),我們才能向服務(wù)器發(fā)送Http請求。這是不對的。我們換個(gè)角度,從服務(wù)器的角度思考。當(dāng)服務(wù)器收到全世界各地發(fā)來的Http請求的時(shí)候,它并不知道屏幕的對面是誰,有可能是正在網(wǎng)上沖浪的你,也有可能僅僅是一只網(wǎng)絡(luò)爬蟲,甚至有可能就是我們編寫的AJAX程序中的XMLHttpRequest對象而已。
??回到我們的問題,XMLHttpRequest對象的本質(zhì)是什么?
是一個(gè)可以發(fā)送Http請求,處理Http響應(yīng),與服務(wù)器之間進(jìn)行異步交換數(shù)據(jù)的對象,其核心是Http。
??所以要想深入理解XMLHttpRequest對象,那就要學(xué)習(xí)一些Http的知識(shí)了。請往下看。
二、Http請求一個(gè)Http請求由4部分組成:
Http請求方法(GET、POST、DELETE、PUT)
正在請求的URL(/home/index.html)
請求頭(可選)
請求主體(可選)
創(chuàng)建XMLHttpRequest對象之后,發(fā)起Http請求的下一步是調(diào)用XMLHttpRequest對象的open()方法去指定這個(gè)請求的兩個(gè)必要部分:請求方法和URL。
request.open("GET",/home/index.html);//請求方法:GET,URL:/home/index.html
open()的第一個(gè)參數(shù)指定Http請求方法,通常用大寫字母來匹配Http協(xié)議。open()的第二個(gè)參數(shù)是URL,是請求的主要內(nèi)容。如果有請求頭的話,請求進(jìn)程的下一個(gè)步驟是設(shè)置它。例如,POST請求需要“Content-type”。
request.setRequestHeader("Content-type","text/plain");
使用XMLHttpRequest發(fā)起Http請求的最后一步是指定請求主體(可選)并向服務(wù)器發(fā)送它。使用send()方法像如下這樣做:
request.send(null);
GET請求沒有主體,所以應(yīng)該傳遞null或省略這個(gè)參數(shù)。
Http請求的各部分有指定順序:請求方法和URL首先到達(dá),然后是請求頭,最后是請求主體。調(diào)用XMLHttpRequest方法的順序必須匹配Http請求的順序。例如:setRequestHeader()方法的調(diào)用必須在open()方法之后,send()方法之前,否則將拋出異常。
例:用POST方法發(fā)送純文本給服務(wù)器
function postMessage(msg){ var request = new XMLHttpRequest(); //創(chuàng)建新請求 request.open("POST","/log.php"); //用POST向服務(wù)器端發(fā)送腳本 request.setRequestHeader("Content-type","text/plain;charset=UTF-8"); //請求頭設(shè)置 request.send(msg); //把msg作為請求主體發(fā)送 } //由于沒有指定響應(yīng)函數(shù),所以我們將忽略任何響應(yīng)三、Http響應(yīng)
服務(wù)器返回的Http響應(yīng)包含3部分:
數(shù)字和文字組成的狀態(tài)碼,用來顯示請求的成功和失敗
響應(yīng)頭
響應(yīng)主體
我們可以通過XMLHttpRequest對象的屬性和方法來獲取上述響應(yīng)包括的三個(gè)部分。
status和statusText屬性以數(shù)字和文本的形式返回Http狀態(tài)碼。
使用getResponseHeader()和getAllResponseHeaders()能查詢響應(yīng)頭。
響應(yīng)主體可以從responseText屬性中得到文本形式的,從responseXML屬性中得到Document形式的。
readyState是一個(gè)整數(shù),指定了Http請求的狀態(tài)。
表:XMLHttpRequest的readyState值
常量 | 值 | 含義 |
---|---|---|
UNSENT | 0 | open()尚未調(diào)用 |
OPENED | 1 | open()已經(jīng)調(diào)用 |
HEADERS_RECEIVED | 2 | 接收到頭信息 |
LOADING | 3 | 接收到響應(yīng)主體 |
DONE | 4 | 響應(yīng)完成 |
為了監(jiān)聽readystatechange事件,請把事件處理函數(shù)設(shè)置為XMLHttpRequest對象的onreadystatechange屬性。
例:獲取Http響應(yīng)的onreadystatechange
//發(fā)出一個(gè)Http GET請求以獲得指定URL的內(nèi)容 //當(dāng)響應(yīng)成功到達(dá),驗(yàn)證它是否是純文本 //如果是,把它傳遞給指定回調(diào)函數(shù) function getText(url,callback){ var request = new XMLHttpRequest(); //創(chuàng)建新請求 request.open("GET",url); //指定待獲取的URL request.onreadystatechange = funciton(){ //定義事件處理函數(shù) if (request.readyState===4&&request.status===200{ //如果請求完成,則它是成功的 var type = request.getResponseHeader("Content-Type"); if(type.match(/^text/)) //確保響應(yīng)是文本 callback(request.responseText); //把它傳遞給回調(diào)函數(shù) } }; request.send(null) //立即發(fā)送請求 }四、總結(jié)
本文介紹了XMLHttpRequest對象的本質(zhì)是一個(gè)可以發(fā)送Http請求,處理Http響應(yīng),與服務(wù)器之間進(jìn)行異步交換數(shù)據(jù)的對象,其核心是Http。然后介紹了Http請求和響應(yīng)包括的具體內(nèi)容。Http請求包括:方法,URL,請求頭,請求主體。Http響應(yīng)包:狀態(tài)碼,響應(yīng)頭和響應(yīng)主體。
參考文獻(xiàn):
[1]維基百科
[2]JavaScript權(quán)威指南
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/81196.html
摘要:創(chuàng)建對象指定響應(yīng)函數(shù)打開連接指定請求發(fā)送請求創(chuàng)建響應(yīng)函數(shù)注第三步是使用對象的方法,字面意思是打開的意思,即打開連接。 前言 博主博客:Stillwater的博客知乎專欄:前端汪汪本文為作者原創(chuàng)轉(zhuǎn)載請注明出處:http://hiztx.top/2017/01/12/a... 在前端面試的時(shí)候經(jīng)常會(huì)有如下情景。AJAX會(huì)嗎?能不能手寫個(gè)AJAX?第一個(gè)問題可以參見我的另一篇博客,AJAX...
摘要:本文主要是我學(xué)習(xí)的筆記,不涉及到原理,只是記錄如何使用。成功的含義取決于方法資源已被提取并在消息正文中傳輸。是請求鏈接到服務(wù)器,服務(wù)器響應(yīng)錯(cuò)誤后服務(wù)器返回瀏覽器的狀態(tài)碼。是指響應(yīng)時(shí)間,開始請求到接收到響應(yīng)開始處理的時(shí)間,單位為。 本文主要是我學(xué)習(xí)ajax的筆記,不涉及到原理,只是記錄如何使用。如果有錯(cuò)歡迎各位大佬指出。提前先轉(zhuǎn)一篇寫的非常全面的博客你真的會(huì)使用XMLHttpReques...
摘要:實(shí)現(xiàn)流程創(chuàng)建對象打開請求地址,初始化數(shù)據(jù)發(fā)送請求數(shù)據(jù)監(jiān)聽回調(diào)函數(shù)狀態(tài)收到服務(wù)器返回的應(yīng)答結(jié)果。請求完成后回調(diào)函數(shù)請求成功或失敗時(shí)均調(diào)用。 Ajax在前端開發(fā)中有著舉足輕重的地位,關(guān)于Ajax的使用和注意事項(xiàng)一直是一個(gè)重要的話題,借此機(jī)會(huì),本文希望對Ajax做一個(gè)全面的總結(jié),徹底揭開Ajax的神秘面紗。 一.什么是Ajax Ajax(Asynchronous JavaScript and...
摘要:一定在發(fā)送請求之前注冊不管同步或者異步為了讓這個(gè)事件可以更加可靠一定觸發(fā),一定是先注冊了解同步模式即可,切記不要使用同步模式。至此,我們已經(jīng)大致了解了的基本。一種數(shù)據(jù)描述手段,基本現(xiàn)在的項(xiàng)目不用了,淘汰的原因數(shù)據(jù)冗余太多。 什么是ajax? AJAX 就是瀏覽器提供的一套 API,可以通過 JavaScript 調(diào)用,從而實(shí)現(xiàn)通過代碼控制請求與響應(yīng)。實(shí)現(xiàn)網(wǎng)絡(luò)編程 1、使用 AJAX 的...
摘要:一定在發(fā)送請求之前注冊不管同步或者異步為了讓這個(gè)事件可以更加可靠一定觸發(fā),一定是先注冊了解同步模式即可,切記不要使用同步模式。至此,我們已經(jīng)大致了解了的基本。一種數(shù)據(jù)描述手段,基本現(xiàn)在的項(xiàng)目不用了,淘汰的原因數(shù)據(jù)冗余太多。 什么是ajax? AJAX 就是瀏覽器提供的一套 API,可以通過 JavaScript 調(diào)用,從而實(shí)現(xiàn)通過代碼控制請求與響應(yīng)。實(shí)現(xiàn)網(wǎng)絡(luò)編程 1、使用 AJAX 的...
閱讀 2042·2023-04-26 01:33
閱讀 1669·2023-04-26 00:52
閱讀 1052·2021-11-18 13:14
閱讀 5466·2021-09-26 10:18
閱讀 2919·2021-09-22 15:52
閱讀 1498·2019-08-29 17:15
閱讀 3028·2019-08-29 16:11
閱讀 1046·2019-08-29 16:11