Ajax與Comet-JavaScript高級(jí)程序設(shè)計(jì)第21章讀書筆記(1)

Ajax(Asynchronous Javascript + XML)技術(shù)的核心是XMLHttpRequest對(duì)象,即: XHR犹菇。雖然名字中包含XML袍睡,但它所指的僅僅是這種無須刷新頁面即可從服務(wù)器端獲取數(shù)據(jù)的技術(shù)篓叶,其通信與數(shù)據(jù)格式無關(guān)沪蓬,并不一定是XML數(shù)據(jù)彤钟。

XMLHttpRequest對(duì)象

IE7+、Firefox跷叉、Opera逸雹、Chrome 和 Safari 都支持原生的XHR對(duì)象。我們可以直接使用XMLHttpRequest構(gòu)造函數(shù)來創(chuàng)建XHR對(duì)象云挟。

var xhr = new XMLHttpRequest();

雖然梆砸,IE7之前版本的瀏覽器中,創(chuàng)建xhr的方法與此有所不同园欣,但是帖世,前端技術(shù)發(fā)展到今天,已經(jīng)很少有業(yè)務(wù)需求是要支持IE7之前的版本了沸枯。因此日矫,這里我略過這一情況。

XHR的用法

使用 XHR對(duì)象的時(shí)候绑榴,要調(diào)用的第一個(gè)方法是open()哪轿,它接受3個(gè)參數(shù):

  1. 要發(fā)送請(qǐng)求的類型,如: get/post
  2. 請(qǐng)求的url
  3. 是否異步發(fā)送請(qǐng)求翔怎,這個(gè)參數(shù)是一個(gè)布爾值

xhr.open('get', 'example.php', false)

注意:open()方法的調(diào)用并不會(huì)真正發(fā)送請(qǐng)求窃诉,僅僅是啟動(dòng)一個(gè)請(qǐng)求以備發(fā)送!

另外,只能向同一個(gè)域中使用相同端口和協(xié)議的URL發(fā)送請(qǐng)求赤套,否則飘痛,會(huì)出現(xiàn)錯(cuò)誤。

在執(zhí)行open()方法之后于毙,必須再調(diào)用send()方法敦冬,才會(huì)真正發(fā)起ajax請(qǐng)求。

xhr.open('get', 'example.txt', false);
xhr.send(null);

send()方法接收一個(gè)參數(shù)唯沮,即:要作為請(qǐng)求主體發(fā)送的數(shù)據(jù)脖旱。如果不需要發(fā)送數(shù)據(jù)堪遂,那么必須傳入null,因?yàn)樵搮?shù)對(duì)于部分瀏覽器而言是必需的萌庆。

本例中的請(qǐng)求是同步的溶褪,Javascript代碼會(huì)等到服務(wù)器響應(yīng)之后再執(zhí)行。
收到響應(yīng)后践险,響應(yīng)的數(shù)據(jù)會(huì)自動(dòng)填充XHR對(duì)象的屬性猿妈,相關(guān)的屬性有:

  1. responseText: 作為響應(yīng)主體被返回的文本。
  2. responseXML: 如果響應(yīng)的內(nèi)容類型是"text/xml"或者"application/xml"巍虫,那么這個(gè)屬性中將保存著包含響應(yīng)數(shù)據(jù)的XML DOM文檔彭则。
  3. status: 響應(yīng)的HTTP狀態(tài)
  4. statusText: HTTP狀態(tài)的說明

無論內(nèi)容類型是什么,響應(yīng)主體的內(nèi)容都會(huì)保存到responseText屬性中占遥,而對(duì)于非XML數(shù)據(jù)而言俯抖,responseXML 屬性的值將會(huì)是null

收到響應(yīng)后瓦胎,一般來說芬萍,會(huì)先判斷 status 是否為200,這是此次請(qǐng)求成功的標(biāo)志搔啊。此時(shí)柬祠,responseText屬性的內(nèi)容已經(jīng)就緒,而且在內(nèi)容類型正確的情況下负芋,responseXML也能夠訪問了漫蛔。
另外,狀態(tài)碼status如果是304示罗,那么表示請(qǐng)求的資源沒有被修改惩猫,可以直接使用瀏覽器中的緩存,當(dāng)然蚜点,這樣的響應(yīng)也是有效的。

if( (xhr.status >= 200 && xhr.status < 300) || xhr.status == 304 ){
    alert(xhr.responseText);
}
else{
    alert('fail! status:' + xhr.status);
}

有的瀏覽器會(huì)錯(cuò)誤地報(bào)告 204 的狀態(tài)代碼拌阴。IE中 XHR 的ActiveX版本會(huì)將204設(shè)置為1223绍绘,而IE中原生的 XHR 則會(huì)將 204 規(guī)范化為 200。Opera會(huì)在取得204時(shí)報(bào)告 status的值為0迟赃。

原文鏈接:http://www.4455q.com/ajax-comet-javascript-chapter21-note1.html

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末陪拘,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子纤壁,更是在濱河造成了極大的恐慌左刽,老刑警劉巖狂打,帶你破解...
    沈念sama閱讀 217,734評(píng)論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件瘸味,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)劳秋,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,931評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來牡昆,“玉大人砰诵,你說我怎么就攤上這事∑凶桑” “怎么了吠式?”我有些...
    開封第一講書人閱讀 164,133評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長抽米。 經(jīng)常有香客問我特占,道長,這世上最難降的妖魔是什么云茸? 我笑而不...
    開封第一講書人閱讀 58,532評(píng)論 1 293
  • 正文 為了忘掉前任是目,我火速辦了婚禮,結(jié)果婚禮上查辩,老公的妹妹穿的比我還像新娘胖笛。我一直安慰自己,他們只是感情好宜岛,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,585評(píng)論 6 392
  • 文/花漫 我一把揭開白布长踊。 她就那樣靜靜地躺著,像睡著了一般萍倡。 火紅的嫁衣襯著肌膚如雪身弊。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,462評(píng)論 1 302
  • 那天列敲,我揣著相機(jī)與錄音阱佛,去河邊找鬼。 笑死戴而,一個(gè)胖子當(dāng)著我的面吹牛凑术,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播所意,決...
    沈念sama閱讀 40,262評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼淮逊,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了扶踊?” 一聲冷哼從身側(cè)響起泄鹏,我...
    開封第一講書人閱讀 39,153評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎秧耗,沒想到半個(gè)月后备籽,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,587評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡分井,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,792評(píng)論 3 336
  • 正文 我和宋清朗相戀三年车猬,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了霉猛。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,919評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡诈唬,死狀恐怖韩脏,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情铸磅,我是刑警寧澤赡矢,帶...
    沈念sama閱讀 35,635評(píng)論 5 345
  • 正文 年R本政府宣布,位于F島的核電站阅仔,受9級(jí)特大地震影響吹散,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜八酒,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,237評(píng)論 3 329
  • 文/蒙蒙 一空民、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧羞迷,春花似錦界轩、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,855評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至热鞍,卻和暖如春葫慎,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背薇宠。 一陣腳步聲響...
    開封第一講書人閱讀 32,983評(píng)論 1 269
  • 我被黑心中介騙來泰國打工偷办, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人澄港。 一個(gè)月前我還...
    沈念sama閱讀 48,048評(píng)論 3 370
  • 正文 我出身青樓椒涯,卻偏偏與公主長得像,于是被迫代替她去往敵國和親回梧。 傳聞我的和親對(duì)象是個(gè)殘疾皇子逐工,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,864評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容