ajax實現(xiàn)原理

1.什么是AJAX?

AJAX全稱為“Asynchronous JavaScript and XML”(異步JavaScript和XML)闪水,是一種創(chuàng)建交互式網(wǎng)頁應用的網(wǎng)頁開發(fā)技術(shù)蒙具。它使用:

使用XHTML+CSS來標準化呈現(xiàn);

使用XML和XSLT進行數(shù)據(jù)交換及相關(guān)操作;

使用XMLHttpRequest對象與Web服務器進行異步數(shù)據(jù)通信融师;

使用Javascript操作Document Object Model進行動態(tài)顯示及交互蚁吝;

使用JavaScript綁定和處理所有數(shù)據(jù)

2.與傳統(tǒng)的web應用比較

傳統(tǒng)的Web應用交互由用戶觸發(fā)一個HTTP請求到服務器,服務器對其進行處理后再返回一個新的HTHL頁到客戶端,

每當服務器處理客戶端提交的請求時,客戶都只能空閑等待,并且哪怕只是一次很小的交互、只需從服務器端得到很

簡單的一個數(shù)據(jù),都要返回一個完整的HTML頁,而用戶每次都要浪費時間和帶寬去重新讀取整個頁面怀伦。這個做法浪費

了許多帶寬山林,由于每次應用的交互都需要向服務器發(fā)送請求,應用的響應時間就依賴于服務器的響應時間驼抹。這導致了

用戶界面的響應比本地應用慢得多框冀。

3.AJAX的工作原理

Ajax的工作原理相當于在用戶和服務器之間加了—個中間層(AJAX引擎),使用戶操作與服務器響應異步化。并不是所有

的用戶請求都提交給服務器,像—些數(shù)據(jù)驗證和數(shù)據(jù)處理等都交給Ajax引擎自己來做, 只有確定需要從服務器讀取新數(shù)據(jù)

時再由Ajax引擎代為向服務器提交請求明也。

Ajax其核心有JavaScript温数、XMLHTTPRequest、DOM對象組成撑刺,通過XmlHttpRequest對象來向服務器發(fā)異步請求,

從服務器獲得數(shù)據(jù)次员,然后用JavaScript來操作DOM而更新頁面。這其中最關(guān)鍵的一步就是從服務器獲得請求數(shù)據(jù)市殷。

讓我們來了解這幾個對象刹衫。與此不同,AJAX應用可以僅向服務器發(fā)送并取回必需的數(shù)據(jù)音羞,它使用SOAP或

其它一些基于XML的Web Service接口仓犬,并在客戶端采用JavaScript處理來自服務器的響應。因為在服務器和瀏覽器

之間交換的數(shù)據(jù)大量減少搀继,結(jié)果我們就能看到響應更快的應用。同時很多的處理工作可以在發(fā)出請求的客戶端機器上完成财边,

所以Web服務器的處理時間也減少了

(1).XMLHTTPRequest對象

Ajax的一個最大的特點是無需刷新頁面便可向服務器傳輸或讀寫數(shù)據(jù)(又稱無刷新更新頁面),這一特點主要得益于XMLHTTP組件XMLHTTPRequest對象点骑。

XMLHttpRequest 對象方法描述

方 ? ?法 描 ? ?述

abort() 停止當前請求

getAllResponseHeaders() 把HTTP請求的所有響應首部作為鍵/值對返回

getResponseHeader("header") ? ?返回指定首部的串值

open("method","URL",[asyncFlag],["userName"],["password"]) 建立對服務器的調(diào)用黑滴。method參數(shù)可以是GET、POST或PUT跷跪。url參數(shù)可以是相對URL或絕對URL。這個方法還包括3個可選的參數(shù)葛菇,是否異步橡羞,用戶名,密碼

send(content) ?向服務器發(fā)送請求

setRequestHeader("header", "value") 把指定首部設置為所提供的值莺债。在設置任何首部之前必須先調(diào)用open()。設置header并和請求一起發(fā)送 ('post'方法一定要 )

XMLHttpRequest 對象屬性描述

屬 ?性 描 ? ?述

onreadystatechange 狀態(tài)改變的事件觸發(fā)器椎侠,每個狀態(tài)改變時都會觸發(fā)這個事件處理器措拇,通常會調(diào)用一個JavaScript函數(shù)

readyState 請求的狀態(tài)。有5個可取值:0 = 未初始化浅悉,1 = 正在加載券犁,2 = 已加載,3 = 交互中粘衬,4 = 完成

responseText 服務器的響應色难,返回數(shù)據(jù)的文本等缀。

responseXML 服務器的響應,返回數(shù)據(jù)的兼容DOM的XML文檔對象 尺迂,這個對象可以解析為一個DOM對象噪裕。

responseBody 服務器返回的主題(非文本格式)

responseStream 服務器返回的數(shù)據(jù)流

status 服務器的HTTP狀態(tài)碼(如:404 = "文件末找到" 、200 ="成功" 膳音,等等)

statusText 服務器返回的狀態(tài)文本信息 祭陷,HTTP狀態(tài)碼的相應文本(OK或Not Found(未找到)等等)

(2).JavaScript

JavaScript是一在瀏覽器中大量使用的編程語言。

(3).DOM Document Object Model

DOM是給HTML和XML文件使用的一組API兵志。它提供了文件的結(jié)構(gòu)表述想罕,讓你可以改變其中的內(nèi)容及可見物。其本質(zhì)是建立網(wǎng)頁與Script或

程序語言溝通的橋梁。所有WEB開發(fā)人員可操作及建立文件的屬性笙瑟、方法及事件都以對象來展現(xiàn)(例如腥沽,document就代表“文件本身“這個對像,

table對象則代表HTML的表格對象等等)师溅。這些對象可以由當今大多數(shù)的瀏覽器以Script來取用盾舌。一個用HTML或XHTML構(gòu)建的網(wǎng)頁也可以看作是一組結(jié)構(gòu)化的數(shù)據(jù),

這些數(shù)據(jù)被封在DOM(Document Object Model)中窿锉,DOM提供了網(wǎng)頁中各個對象的讀寫的支持膝舅。

(4).XML

可擴展的標記語言(Extensible Markup Language)具有一種開放的、可擴展的洼滚、可自描述的語言結(jié)構(gòu)技潘,它已經(jīng)成為網(wǎng)上數(shù)據(jù)和文檔傳輸?shù)臉藴?用于其他應用程序交換數(shù)據(jù)

(5).綜合

Ajax引擎,實際上是一個比較復雜的JavaScript應用程序铲掐,用來處理用戶請求值桩,讀寫服務器和更改DOM內(nèi)容。JavaScript的Ajax引擎讀取信息携栋,并且互動地重寫DOM

蛀蜜,這使網(wǎng)頁能無縫化重構(gòu),也就是在頁面已經(jīng)下載完畢后改變頁面內(nèi)容磅摹,這是我們一直在通過JavaScript和DOM在廣泛使用的方法,但要使網(wǎng)頁真正動態(tài)起來户誓,不僅要內(nèi)部的互動,

還需要從外部獲取數(shù)據(jù)碍彭,在以前悼潭,我們是讓用戶來輸入數(shù)據(jù)并通過DOM來改變網(wǎng)頁內(nèi)容的,但現(xiàn)在皆疹,XMLHTTPRequest占拍,可以讓我們在不重載頁面的情況下讀寫服務器上的數(shù)據(jù),使用戶的輸入達到最少表牢。

4.AJAX的優(yōu)缺點

(1).AJAX的優(yōu)點

<1>.無刷新更新數(shù)據(jù)贝次。

AJAX最大優(yōu)點就是能在不刷新整個頁面的前提下與服務器通信維護數(shù)據(jù)。這使得Web應用程序更為迅捷地響應用戶交互恼布,并避免了在網(wǎng)絡上發(fā)送那些沒有改變的信息搁宾,減少用戶等待時間倔幼,帶來非常好的用戶體驗损同。

<2>.異步與服務器通信。

AJAX使用異步方式與服務器通信膏燃,不需要打斷用戶的操作组哩,具有更加迅速的響應能力处渣。優(yōu)化了Browser和Server之間的溝通蛛砰,減少不必要的數(shù)據(jù)傳輸、時間及降低網(wǎng)絡上數(shù)據(jù)流量荠诬。

<3>.前端和后端負載平衡位仁。

AJAX可以把以前一些服務器負擔的工作轉(zhuǎn)嫁到客戶端,利用客戶端閑置的能力來處理凌外,減輕服務器和帶寬的負擔涛浙,節(jié)約空間和寬帶租用成本。

并且減輕服務器的負擔疮薇,AJAX的原則是“按需取數(shù)據(jù)”我注,可以最大程度的減少冗余請求和響應對服務器造成的負擔,提升站點性能

<4>.基于標準被廣泛支持励七。

AJAX基于標準化的并被廣泛支持的技術(shù)奔缠,不需要下載瀏覽器插件或者小程序,但需要客戶允許JavaScript在瀏覽器上執(zhí)行两波。隨著Ajax的成熟闷哆,一些簡化Ajax使用方法的程序庫也相繼問世。同樣劣坊,也出現(xiàn)了另一種輔助程序設計的技術(shù)屈留,為那些不支持JavaScript的用戶提供替代功能括儒。

<5>.界面與應用分離帮寻。

Ajax使WEB中的界面與應用分離(也可以說是數(shù)據(jù)與呈現(xiàn)分離)赠摇,有利于分工合作、減少非技術(shù)人員對頁面的修改造成的WEB應用程序錯誤烫罩、提高效率洽故、也更加適用于現(xiàn)在的發(fā)布系統(tǒng)

(2).AJAX的缺點

<1>.AJAX干掉了Back和History功能,即對瀏覽器機制的破壞隘弊。

在動態(tài)更新頁面的情況下荒适,用戶無法回到前一個頁面狀態(tài),因為瀏覽器僅能記憶歷史記錄中的靜態(tài)頁面咽扇。一個被完整讀入的頁面與一個已經(jīng)被動態(tài)修改過的頁面之間的差別非常微妙陕壹;

用戶通常會希望單擊后退按鈕能夠取消他們的前一次操作,但是在Ajax應用程序中嘶伟,這將無法實現(xiàn)榨惠。

用過Gmail的知道盛霎,Gmail下面采用的Ajax技術(shù)解決了這個問題愤炸,在Gmail下面是可以后退的,

但是规个,它也并不能改變Ajax的機制,它只是采用的一個比較笨但是有效的辦法缤苫,即用戶單擊后退按鈕訪問歷史記錄時活玲,

通過創(chuàng)建或使用一個隱藏的IFRAME來重現(xiàn)頁面上的變更。

一個相關(guān)的觀點認為镀钓,使用動態(tài)頁面更新使得用戶難于將某個特定的狀態(tài)保存到收藏夾中镀迂。該問題的解決方案也已出現(xiàn),大部分都使用URL片斷標識符(通常被稱為錨點窟赏,即URL中#后面的部分)來保持跟蹤箱季,

允許用戶回到指定的某個應用程序狀態(tài)。(許多瀏覽器允許JavaScript動態(tài)更新錨點求豫,這使得Ajax應用程序能夠在更新顯示內(nèi)容的同時更新錨點诉稍。)這些解決方案也同時解決了許多關(guān)于不支持后退按鈕的爭論

<2>.AJAX的安全問題杯巨。

AJAX技術(shù)給用戶帶來很好的用戶體驗的同時也對IT企業(yè)帶來了新的安全威脅,Ajax技術(shù)就如同對企業(yè)數(shù)據(jù)建立了一個直接通道服爷。這使得開發(fā)者在不經(jīng)意間會暴露比以前更多的數(shù)據(jù)和服務器邏輯仍源。

Ajax的邏輯可以對客戶端的安全掃描技術(shù)隱藏起來,允許黑客從遠端服務器上建立新的攻擊逗爹。還有Ajax也難以避免一些已知的安全弱點嚎于,諸如跨站點腳步攻擊挟冠、SQL注入攻擊和基于Credentials的安全漏洞等等知染。

<3>.對搜索引擎支持較弱斑胜。

對搜索引擎的支持比較弱。如果使用不當逸寓,AJAX會增大網(wǎng)絡數(shù)據(jù)的流量覆山,從而降低整個系統(tǒng)的性能。

<4>.破壞程序的異常處理機制勋篓。

至少從目前看來魏割,像Ajax.dll钞它,Ajaxpro.dll這些Ajax框架是會破壞程序的異常機制的。關(guān)于這個問題遭垛,曾在開發(fā)過程中遇到過锯仪,但是查了一下網(wǎng)上幾乎沒有相關(guān)的介紹。后來做了一次試驗庶喜,分別采用Ajax和傳統(tǒng)的form提交的模式來刪除一條數(shù)據(jù)……給我們的調(diào)試帶來了很大的困難久窟。

<5>.違背URL和資源定位的初衷。

例如漩仙,我給你一個URL地址犹赖,如果采用了Ajax技術(shù),也許你在該URL地址下面看到的和我在這個URL地址下看到的內(nèi)容是不同的麸折。這個和資源定位的初衷是相背離的粘昨。

<6>.AJAX不能很好支持移動設備张肾。

一些手持設備(如手機、PDA等)現(xiàn)在還不能很好的支持Ajax馁启,比如說我們在手機的瀏覽器上打開采用Ajax技術(shù)的網(wǎng)站時芍秆,它目前是不支持的。

<7>.客戶端過肥霉颠,太多客戶端代碼造成開發(fā)上的成本荆虱。

編寫復雜怀读、容易出錯 ;冗余代碼比較多(層層包含js文件是AJAX的通病不从,再加上以往的很多服務端代碼現(xiàn)在放到了客戶端)犁跪;破壞了Web的原有標準。

5.AJAX注意點及適用和不適用場景

(1).注意點

Ajax開發(fā)時寝优,網(wǎng)絡延遲——即用戶發(fā)出請求到服務器發(fā)出響應之間的間隔——需要慎重考慮枫耳。不給予用戶明確的回應,沒有恰當?shù)念A讀數(shù)據(jù)钻心,或者對XMLHttpRequest的不恰當處理捷沸,

都會使用戶感到延遲,這是用戶不希望看到的说墨,也是他們無法理解的苍柏。通常的解決方案是,使用一個可視化的組件來告訴用戶系統(tǒng)正在進行后臺操作并且正在讀取數(shù)據(jù)和內(nèi)容

(2).Ajax適用場景

<1>.表單驅(qū)動的交互

<2>.深層次的樹的導航

<3>.快速的用戶與用戶間的交流響應

<4>.類似投票棺棵、yes/no等無關(guān)痛癢的場景

<5>.對數(shù)據(jù)進行過濾和操縱相關(guān)數(shù)據(jù)的場景

<6>.普通的文本輸入提示和自動完成的場景

(3).Ajax不適用場景

<1>.部分簡單的表單

<2>.搜索

<3>.基本的導航

<4>.替換大量的文本

<5>.對呈現(xiàn)的操縱

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末律秃,一起剝皮案震驚了整個濱河市棒动,隨后出現(xiàn)的幾起案子宾添,更是在濱河造成了極大的恐慌,老刑警劉巖粱锐,帶你破解...
    沈念sama閱讀 210,978評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件怜浅,死亡現(xiàn)場離奇詭異蔬崩,居然都是意外死亡沥阳,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,954評論 2 384
  • 文/潘曉璐 我一進店門脉让,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人术唬,你說我怎么就攤上這事伟恶〔╋” “怎么了眶掌?”我有些...
    開封第一講書人閱讀 156,623評論 0 345
  • 文/不壞的土叔 我叫張陵朴爬,是天一觀的道長。 經(jīng)常有香客問我母赵,道長具滴,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,324評論 1 282
  • 正文 為了忘掉前任,我火速辦了婚禮疲恢,結(jié)果婚禮上凶朗,老公的妹妹穿的比我還像新娘。我一直安慰自己显拳,他們只是感情好棚愤,可當我...
    茶點故事閱讀 65,390評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著杂数,像睡著了一般宛畦。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上耍休,一...
    開封第一講書人閱讀 49,741評論 1 289
  • 那天刃永,我揣著相機與錄音,去河邊找鬼羊精。 笑死囚玫,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的读规。 我是一名探鬼主播抓督,決...
    沈念sama閱讀 38,892評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼束亏!你這毒婦竟也來了铃在?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,655評論 0 266
  • 序言:老撾萬榮一對情侶失蹤碍遍,失蹤者是張志新(化名)和其女友劉穎定铜,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體怕敬,經(jīng)...
    沈念sama閱讀 44,104評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡揣炕,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了东跪。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片畸陡。...
    茶點故事閱讀 38,569評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖虽填,靈堂內(nèi)的尸體忽然破棺而出丁恭,到底是詐尸還是另有隱情,我是刑警寧澤斋日,帶...
    沈念sama閱讀 34,254評論 4 328
  • 正文 年R本政府宣布牲览,位于F島的核電站,受9級特大地震影響桑驱,放射性物質(zhì)發(fā)生泄漏竭恬。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,834評論 3 312
  • 文/蒙蒙 一熬的、第九天 我趴在偏房一處隱蔽的房頂上張望痊硕。 院中可真熱鬧,春花似錦押框、人聲如沸岔绸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,725評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽盒揉。三九已至,卻和暖如春兑徘,著一層夾襖步出監(jiān)牢的瞬間刚盈,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,950評論 1 264
  • 我被黑心中介騙來泰國打工挂脑, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留藕漱,地道東北人欲侮。 一個月前我還...
    沈念sama閱讀 46,260評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像肋联,于是被迫代替她去往敵國和親威蕉。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,446評論 2 348

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