AJAX工作原理及其優缺點

1.AJAX全稱為“Asynchronous JavaScript and XML”(異步JavaScript和XML),是一種創建交互式網頁應用的網頁開發技術。它使用:

使用XHTML+CSS來標準化呈現;

使用XML和XSLT進行數據交換及相關操作;

使用XMLHttpRequest對象與Web服務器進行異步數據通信;

使用Javascript操作Document Object Model進行動態顯示及交互;

使用JavaScript綁定和處理所有數據。

2.傳統的Web應用交互由用戶觸發一個HTTP請求到服務器,服務器對其進行處理后再返回一個新的HTHL頁到客戶端, 每當服務器處理客戶端提交的請求時,客戶都只能空閑等待,并且哪怕只是一次很小的交互、只需從服務器端得到很簡單的一個數據,都要返回一個完整的HTML頁,而用戶每次都要浪費時間和帶寬去重新讀取整個頁面。這個做法浪費了許多帶寬,由于每次應用的交互都需要向服務器發送請求,應用的響應時間就依賴于服務器的響應時間。這導致了用戶界面的響應比本地應用慢得多。

與此不同,AJAX應用可以僅向服務器發送并取回必需的數據,它使用SOAP或其它一些基于XML的Web Service接口,并在客戶端采用JavaScript處理來自服務器的響應。因為在服務器和瀏覽器之間交換的數據大量減少,結果我們就能看到響應更快的應用。同時很多的處理工作可以在發出請求的客戶端機器上完成,所以Web服務器的處理時間也減少了。

3.AJAX的工作原理:Ajax的工作原理相當于在用戶和服務器之間加了—個中間層(AJAX引擎),使用戶操作與服務器響應異步化。并不是所有的用戶請求都提交給服務器,像—些數據驗證和數據處理等都交給Ajax引擎自己來做,只有確定需要從服務器讀取新數據時再由Ajax引擎代為向服務器提交請求。

Ajax其核心有JavaScript、XMLHTTPRequest、DOM對象組成,通過XmlHttpRequest對象來向服務器發異步請求,從服務器獲得數據,然后用JavaScript來操作DOM而更新頁面。這其中最關鍵的一步就是從服務器獲得請求數據。讓我們來了解這幾個對象。

(1).XMLHTTPRequest對象

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

XMLHttpRequest 對象方法描述:

abort():停止當前請求

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

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

open("method","URL",[asyncFlag],["userName"],["password"]):建立對服務器的調用。method參數可以是GET、POST或PUT。url參數可以是相對URL或絕對URL。這個方法還包括3個可選的參數,是否異步,用戶名,密碼

send(content):向服務器發送請求

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

XMLHttpRequest 對象屬性描述:

onreadystatechange:狀態改變的事件觸發器,每個狀態改變時都會觸發這個事件處理器,通常會調用一個JavaScript函數

readyState:請求的狀態。有5個可取值:0 = 未初始化,對象已建立,但是尚未初始化(尚未調用open方法),1 = 正在加載,對象已建立,尚未調用send方法,2 = 已加載,send方法已調用,但是當前的狀態及http頭未知,3 = 交互中,已接收部分數據,因為響應及http頭不全,這時通過responseBody和responseText獲取部分數據會出現錯誤,4 = 完成,數據接收完畢,此時可以通過通過responseXml和responseText獲取完整的回應數據

responseText:服務器的響應,返回數據的文本。

responseXML:服務器的響應,返回數據的兼容DOM的XML文檔對象 ,這個對象可以解析為一個DOM對象。

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

responseStream:服務器返回的數據流

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

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

Ajax引擎,實際上是一個比較復雜的JavaScript應用程序,用來處理用戶請求,讀寫服務器和更改DOM內容。JavaScript的Ajax引擎讀取信息,并且互動地重寫DOM,這使網頁能無縫化重構,也就是在頁面已經下載完畢后改變頁面內容,這是我們一直在通過JavaScript和DOM在廣泛使用的方法,但要使網頁真正動態起來,不僅要內部的互動,還需要從外部獲取數據,在以前,我們是讓用戶來輸入數據并通過DOM來改變網頁內容的,但現在,XMLHTTPRequest,可以讓我們在不重載頁面的情況下讀寫服務器上的數據,使用戶的輸入達到最少。

Ajax使WEB中的界面與應用分離(也可以說是數據與呈現分離),而在以前兩者是沒有清晰的界限的,數據與呈現分離的分離,有利于分工合作、減少非技術人員對頁面的修改造成的WEB應用程序錯誤、提高效率、也更加適用于現在的發布系統。也可以把以前的一些服務器負擔的工作轉嫁到客戶端,利于客戶端閑置的處理能力來處理。

4.AJAX的優點

<1>.無刷新更新數據。

AJAX最大優點就是能在不刷新整個頁面的前提下與服務器通信維護數據。這使得Web應用程序更為迅捷地響應用戶交互,并避免了在網絡上發送那些沒有改變的信息,減少用戶等待時間,帶來非常好的用戶體驗。

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

AJAX使用異步方式與服務器通信,不需要打斷用戶的操作,具有更加迅速的響應能力。優化了Browser和Server之間的溝通,減少不必要的數據傳輸、時間及降低網絡上數據流量。

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

AJAX可以把以前一些服務器負擔的工作轉嫁到客戶端,利用客戶端閑置的能力來處理,減輕服務器和帶寬的負擔,節約空間和寬帶租用成本。并且減輕服務器的負擔,AJAX的原則是“按需取數據”,可以最大程度的減少冗余請求和響應對服務器造成的負擔,提升站點性能。

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

AJAX基于標準化的并被廣泛支持的技術,不需要下載瀏覽器插件或者小程序,但需要客戶允許JavaScript在瀏覽器上執行。隨著Ajax的成熟,一些簡化Ajax使用方法的程序庫也相繼問世。同樣,也出現了另一種輔助程序設計的技術,為那些不支持JavaScript的用戶提供替代功能。

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

Ajax使WEB中的界面與應用分離(也可以說是數據與呈現分離),有利于分工合作、減少非技術人員對頁面的修改造成的WEB應用程序錯誤、提高效率、也更加適用于現在的發布系統。

5.ajax的缺點

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

在動態更新頁面的情況下,用戶無法回到前一個頁面狀態,因為瀏覽器僅能記憶歷史記錄中的靜態頁面。一個被完整讀入的頁面與一個已經被動態修改過的頁面之間的差別非常微妙;用戶通常會希望單擊后退按鈕能夠取消他們的前一次操作,但是在Ajax應用程序中,這將無法實現。

后退按鈕是一個標準的web站點的重要功能,但是它沒法和js進行很好的合作。這是Ajax所帶來的一個比較嚴重的問題,因為用戶往往是希望能夠通過后退來取消前一次操作的。那么對于這個問題有沒有辦法?答案是肯定的,用過Gmail的知道,Gmail下面采用的Ajax技術解決了這個問題,在Gmail下面是可以后退的,但是,它也并不能改變Ajax的機制,它只是采用的一個比較笨但是有效的辦法,即用戶單擊后退按鈕訪問歷史記錄時,通過創建或使用一個隱藏的IFRAME來重現頁面上的變更。(例如,當用戶在Google Maps中單擊后退時,它在一個隱藏的IFRAME中進行搜索,然后將搜索結果反映到Ajax元素上,以便將應用程序狀態恢復到當時的狀態。)

但是,雖然說這個問題是可以解決的,但是它所帶來的開發成本是非常高的,并與Ajax框架所要求的快速開發是相背離的。這是Ajax所帶來的一個非常嚴重的問題。

一個相關的觀點認為,使用動態頁面更新使得用戶難于將某個特定的狀態保存到收藏夾中。該問題的解決方案也已出現,大部分都使用URL片斷標識符(通常被稱為錨點,即URL中#后面的部分)來保持跟蹤,允許用戶回到指定的某個應用程序狀態。(許多瀏覽器允許JavaScript動態更新錨點,這使得Ajax應用程序能夠在更新顯示內容的同時更新錨點。)這些解決方案也同時解決了許多關于不支持后退按鈕的爭論。

<2>.AJAX的安全問題。

AJAX技術給用戶帶來很好的用戶體驗的同時也對IT企業帶來了新的安全威脅,Ajax技術就如同對企業數據建立了一個直接通道。這使得開發者在不經意間會暴露比以前更多的數據和服務器邏輯。Ajax的邏輯可以對客戶端的安全掃描技術隱藏起來,允許黑客從遠端服務器上建立新的攻擊。還有Ajax也難以避免一些已知的安全弱點,諸如跨站點腳步攻擊、SQL注入攻擊和基于Credentials的安全漏洞等等。

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

對搜索引擎的支持比較弱。如果使用不當,AJAX會增大網絡數據的流量,從而降低整個系統的性能。

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

至少從目前看來,像Ajax.dll,Ajaxpro.dll這些Ajax框架是會破壞程序的異常機制的。關于這個問題,曾在開發過程中遇到過,但是查了一下網上幾乎沒有相關的介紹。后來做了一次試驗,分別采用Ajax和傳統的form提交的模式來刪除一條數據……給我們的調試帶來了很大的困難。

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

例如,我給你一個URL地址,如果采用了Ajax技術,也許你在該URL地址下面看到的和我在這個URL地址下看到的內容是不同的。這個和資源定位的初衷是相背離的。

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

一些手持設備(如手機、PDA等)現在還不能很好的支持Ajax,比如說我們在手機的瀏覽器上打開采用Ajax技術的網站時,它目前是不支持的。

<7>.客戶端過肥,太多客戶端代碼造成開發上的成本。

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

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

(1).注意點

Ajax開發時,網絡延遲——即用戶發出請求到服務器發出響應之間的間隔——需要慎重考慮。不給予用戶明確的回應,沒有恰當的預讀數據,或者對XMLHttpRequest的不恰當處理,都會使用戶感到延遲,這是用戶不希望看到的,也是他們無法理解的。通常的解決方案是,使用一個可視化的組件來告訴用戶系統正在進行后臺操作并且正在讀取數據和內容。

(2).Ajax適用場景

<1>.表單驅動的交互

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

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

<4>.類似投票、yes/no等無關痛癢的場景

<5>.對數據進行過濾和操縱相關數據的場景

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

(3).Ajax不適用場景

<1>.部分簡單的表單

<2>.搜索

<3>.基本的導航

<4>.替換大量的文本

<5>.對呈現的操縱

7.ajax所包含的技術

大家都知道ajax并非一種新的技術,而是幾種原有技術的結合體。它由下列技術組合而成。

1.使用CSS和XHTML來表示。

2.使用DOM模型來交互和動態顯示。

3.使用XMLHttpRequest來和服務器進行異步通信。

4.使用javascript來綁定和調用。

在上面幾中技術中,除了XmlHttpRequest對象以外,其它所有的技術都是基于web標準并且已經得到了廣泛使用的,XMLHttpRequest雖然目前還沒有被W3C所采納,但是它已經是一個事實的標準,因為目前幾乎所有的主流瀏覽器都支持它。


實例:

function??? CreateXmlHttp() {

//非IE瀏覽器創建XmlHttpRequest對象

if(window.XmlHttpRequest) {

xmlhttp =newXmlHttpRequest();

}

//IE瀏覽器創建XmlHttpRequest對象

if(window.ActiveXObject) {

try{

xmlhttp =newActiveXObject("Microsoft.XMLHTTP");

}

catch(e) {

try{

xmlhttp =newActiveXObject("msxml2.XMLHTTP");

}

catch(ex) { }

}

}

}

functionUstbwuyi() {

vardata = document.getElementById("username").value;

CreateXmlHttp();

if(!xmlhttp) {

alert("創建xmlhttp對象異常!");

returnfalse;

}

xmlhttp.open("POST", url,false);

xmlhttp.onreadystatechange =function() {

if(xmlhttp.readyState == 4) {

document.getElementById("user1").innerHTML = "數據正在加載...";

if(xmlhttp.status == 200) {

document.write(xmlhttp.responseText);

}

}

}

xmlhttp.send();

}

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容