1.什么是AJAX
AJAX全稱是"Asynchronous JavaScript and XML"(異步Javascript和XML),是一種創(chuàng)建交互式網(wǎng)頁應(yīng)用的網(wǎng)頁開發(fā)技術(shù)。它使用
使用XHTML+CSS來標(biāo)準(zhǔn)化呈現(xiàn);
使用XML和XSLT進行數(shù)據(jù)交換及相關(guān)操作
使用XMLHttpRequest對象與Web服務(wù)器進行異步數(shù)據(jù)通信;
使用Javascript操作Document Object Model進行動態(tài)顯示及交互;
使用Javascript綁定和處理所有數(shù)據(jù)
2.與傳統(tǒng)的Web應(yīng)用比較
傳統(tǒng)的Web應(yīng)用交互由用戶觸發(fā)一個HTTP請求到服務(wù)器,服務(wù)器對其進行處理后再返回一個新的HTML頁到客戶端,每當(dāng)服務(wù)器處理客戶端提交的請求時,客戶都只能空閑等待并且哪怕只是一次很小的交互、只需從服務(wù)器端得到很簡單的一個數(shù)據(jù),都要返回一個完整的HTML頁,而用戶每次都要浪費時間和帶寬去重新讀取整個頁面。這個做法浪費了許多帶寬,由于每次應(yīng)用的交互都需要向服務(wù)器發(fā)送請求,應(yīng)用的響應(yīng)時間就依賴于服務(wù)器的響應(yīng)時間。這導(dǎo)致了用戶界面的響應(yīng)比本地應(yīng)用慢得多。
與此不同,AJAX應(yīng)用可以僅向服務(wù)器發(fā)送并取回必需的數(shù)據(jù),它使用SOAP或其它一些基于XML的Web Service接口,并在客戶端采用JavaScript處理來自服務(wù)器的響應(yīng)。因為在服務(wù)器和瀏覽器之間交換的數(shù)據(jù)大量減少,結(jié)果我們就能看到響應(yīng)更快的應(yīng)用。同時很多的處理工作可以在發(fā)出請求的客戶端機器上完成,所以Web服務(wù)器的處理時間也減少了。
3.ajax的工作原理
AJAX的工作原理相當(dāng)于在服務(wù)器和用戶之間加了一個中間層(AJAX引擎)使用戶操作與服務(wù)器響應(yīng)異步化
并不是所有用戶請求都提交給服務(wù)器,像一些數(shù)據(jù)驗證個數(shù)據(jù)處理等都交給AJA引擎自己來做,只有確定需要從服務(wù)器讀取數(shù)據(jù)時在由ajax引擎代為向服務(wù)器提交請求
Ajax其核心有JavaScript、XMLHTTPRequest、DOM對象組成,通過XmlHttpRequest對象來向服務(wù)器發(fā)異步請求,從服務(wù)器獲得數(shù)據(jù),然后用JavaScript來操作DOM而更新頁面。這其中最關(guān)鍵的一步就是從服務(wù)器獲得請求數(shù)據(jù)。讓我們來了解這幾個對象。
(1).XMLHTTPRequest對象
AJAX的一個最大的特點是無需刷新便可向服務(wù)器傳輸或讀取數(shù)據(jù)(又稱不刷新更新頁面)這一特點主要得益于XMLHTTP組件XMLHTPRequest對象
XMLHttpRequest對象方法描述
abort() ? ? ? ? ?停止當(dāng)前請求
getAllResponseHeaders() ? ? ?把HTTP請求的所有響應(yīng)頭部作為鍵/值對返回
getAllResponseHeader("header") ? 返回指定頭部的串值
open() ? ?建立對服務(wù)器的調(diào)用
send() ? ?向服務(wù)器發(fā)送請求
setRequestHeader(header","value") ? ?把指定首部設(shè)置為所提供的值
XMLHttpRequest對象屬性描述
onreadystatechange ? ? 每個狀態(tài)改變的事件觸發(fā)器,通常會調(diào)用一個Javascript函數(shù)
readyState ? ?請求狀態(tài) ?有5個可取值:0=未初始化,1=正在加載,2=已加載,3=交互中,4=完成
responseText ? ?服務(wù)器的相應(yīng),返回數(shù)據(jù)的文本
responseXML ? ? 服務(wù)器的響應(yīng),返回數(shù)據(jù)的兼容DOM的XML文檔對象,這個對象可以解析為一個DOM對象
responseBody ? ?服務(wù)器返回的主題(非文本格式)
responseStream ? ?服務(wù)器返回的數(shù)據(jù)流
status ? 服務(wù)器的HTTP狀態(tài)碼
statusText ? 服務(wù)器返回的狀態(tài)文本信息
(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的表格對象等等)。這些對象可以由當(dāng)今大多數(shù)的瀏覽器以Script來取用。一個用HTML或XHTML構(gòu)建的網(wǎng)頁也可以看作是一組結(jié)構(gòu)化的數(shù)據(jù),這些數(shù)據(jù)被封在DOM(Document Object Model)中,DOM提供了網(wǎng)頁中各個對象的讀寫的支持。
(4).XML
可擴展的標(biāo)記語言(Extensible Markup Language)具有一種開放的、可擴展的、可自描述的語言結(jié)構(gòu),它已經(jīng)成為網(wǎng)上數(shù)據(jù)和文檔傳輸?shù)臉?biāo)準(zhǔn),用于其他應(yīng)用程序交換數(shù)據(jù)。
Ajax引擎,實際上是一個比較復(fù)雜的JavaScript應(yīng)用程序,用來處理用戶請求,讀寫服務(wù)器和更改DOM內(nèi)容并且互動地重寫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,可以讓我們在不重載頁面的情況下讀寫服務(wù)器上的數(shù)據(jù),使用戶的輸入達到最少。
Ajax使WEB中的界面與應(yīng)用分離(也可以說是數(shù)據(jù)與呈現(xiàn)分離),而在以前兩者是沒有清晰的界限的,數(shù)據(jù)與呈現(xiàn)分離的分離,有利于分工合作、減少非技術(shù)人員對頁面的修改造成的WEB應(yīng)用程序錯誤、提高效率、也更加適用于現(xiàn)在的發(fā)布系統(tǒng)。也可以把以前的一些服務(wù)器負擔(dān)的工作轉(zhuǎn)嫁到客戶端,利于客戶端閑置的處理能力來處理。
4.AJAX的優(yōu)點
1》無刷新更新數(shù)據(jù)
2》異步服務(wù)器通信
3》前端和后端負載平衡
4》基于標(biāo)準(zhǔn)備廣泛支持
5》界面與應(yīng)用分離
5.AJAX的缺點
1》AJAX干掉了Back和History功能,即對瀏覽器機制的破壞
2》AJAX安全問題
3》對搜索引擎支持較弱
4》破壞程序的異常處理機制
5》違背了URL和資源定位的初衷
6》AJAX不是很好支持移動設(shè)備
6.AJAX注意點及適用和不適用場景
(1).注意點
Ajax開發(fā)時,網(wǎng)絡(luò)延遲——即用戶發(fā)出請求到服務(wù)器發(fā)出響應(yīng)之間的間隔——需要慎重考慮。不給予用戶明確的回應(yīng),沒有恰當(dāng)?shù)念A(yù)讀數(shù)據(jù),或者對XMLHttpRequest的不恰當(dāng)處理,都會使用戶感到延遲,這是用戶不希望看到的,也是他們無法理解的。通常的解決方案是,使用一個可視化的組件來告訴用戶系統(tǒng)正在進行后臺操作并且正在讀取數(shù)據(jù)和內(nèi)容。
(2).Ajax適用場景
<1>.表單驅(qū)動的交互
<2>.深層次的樹的導(dǎo)航
<3>.快速的用戶與用戶間的交流響應(yīng)
<4>.類似投票、yes/no等無關(guān)痛癢的場景
<5>.對數(shù)據(jù)進行過濾和操縱相關(guān)數(shù)據(jù)的場景
<6>.普通的文本輸入提示和自動完成的場景
(3).Ajax不適用場景
<1>.部分簡單的表單
<2>.搜索
<3>.基本的導(dǎo)航
<4>.替換大量的文本
<5>.對呈現(xiàn)的操縱