PHP-ajax簡介:
AJAX全稱為“Asynchronous JavaScript and
XML”(異步JavaScript和XML),指一種建立互動式網頁應用的網頁開發技術。
Ajax(Asynchronous JavaScript + XML)的定義基于web标準(standards-based presentation)XHTML+CSS的表示;
使用DOM(Document
Object Model)進行動态顯示及互動;
使用 XML 和 XSLT 進行資料交換及相關操作;
使用 XMLHttpRequest
進行異步資料查詢、檢索;
使用 JavaScript
将所有的東西綁定在一起。英文參見Ajax的提出者Jesse
James Garrett的原文。
類似于DHTML或LAMP,AJAX不是指一種單一的技術,而是有機地利用了一系列相關的技術。事實上,一些基于AJAX的“派生/合成”式(derivative/composite)的技術正在出現,如“AFLAX”。
AJAX的應用:
使用支援以上技術的web浏覽器作為運作平台。這些浏覽器目前Mozilla、Firefox、Internet
Explorer、Opera、Konqueror及Safari。但是Opera不支援XS格式對象,也不支援XSLT。
傳統的web應用允許使用者填寫表單(form),當送出表單時就向web伺服器發送一個請求。伺服器接收并處理傳來的表單,然後傳回一個新的網頁。這個做
法浪費了許多帶寬,因為在前後兩個頁面中的大部分HTML代碼往往是相同的。由于每次應用的互動都需要向伺服器發送請求,應用的響應時間就依賴于伺服器的
響應時間。這導緻了使用者界面的響應比本地應用慢得多。 與此不同,AJAX應用可以僅向伺服器發送并取回必需的資料,它使用SOAP或其它一些基于XML的web
service接口,并在用戶端采用JavaScript處理來自伺服器的響應。因為在伺服器和浏覽器之間交換的資料大量減少,結果我們就能看到響應更快
的應用。同時很多的處理工作可以在送出請求的用戶端機器上完成,是以Web伺服器的處理時間也減少了。
Ajax應用程式的優勢在于:
1. 通過異步模式,提升了使用者體驗
2. 優化了浏覽器和伺服器之間的傳輸,減少不必要的資料往返,減少了帶寬占用
3.
Ajax引擎在用戶端運作,承擔了一部分本來由伺服器承擔的工作,進而減少了大使用者量下的伺服器負載。
發展史:
該技術在1998年前後得到了應用。允許用戶端腳本發送HTTP請求(XMLHTTP)的第一個元件由Outlook Web Access小組寫成。 該元件原屬于微軟Exchange Server,并且迅速地成為了Internet
Explorer 4.0[3]的一部分。部分觀察家認為,Outlook
Web Access是第一個應用了Ajax技術的成功的商業應用程式,并成為包括Oddpost的網絡郵件産品在内的許多産品的領頭羊 但是,2005年初,許多事件使得Ajax被大衆所接受。Google在它著名的互動應用程式中使用了異步通訊,如Google讨論組、Google地
圖、Google搜尋建議、Gmail等。Ajax這個詞由《Ajax:
A NewApproach to Web Applications》一文所創,該文的迅速流傳提高了人們使用該項技術的意識。
另外,對Mozilla/Gecko的支援使得該技術走向成熟,變得更為易用。
優點和缺點:
使用Ajax的最大優點,就是能在不更新整個頁面的前提下維護資料。這使得Web應用程式更為迅捷地回應使用者動作,并避免了在網絡上發送那些沒有改變過的資訊。
[1] Ajax不需要任何浏覽器插件,但需要使用者允許JavaScrip在浏覽器上執行。就像DHTML應用程式那樣,Ajax應用程式必須在衆多不同的浏覽
器和平台上經過嚴格的測試。随着Ajax的成熟,一些簡化Ajax使用方法的程式庫也相繼問世。
[2]同樣,也出現了另一種輔助程式設計的技術,為那些不支援 JavaScript的使用者提供替代功能。
[3] 對應用Ajax最主要的批評就是,它可能破壞浏覽器後退按鈕的正常行為
[4]。在動态更新頁面的情況下,使用者無法回到前一個頁狀态,這是因為浏覽器僅能
記下曆史記錄中的靜态頁面。一個被完整讀入的頁面與一個已經被動态修改過的頁面之間的差别非常微妙;使用者通常都希望單擊後退按鈕,就能夠取消他們的前一次
操作,但是在Ajax應用程式中,卻無法這樣做。不過開發者已想出了種種辦法來解決這個問題,當中大多數都是在使用者單擊後退按鈕通路曆史記錄時,通過建立
或使用一個隐藏的IFRAME來重制頁面上的變更。(例如,當使用者在Google
Maps中單擊後退時,它在一個隐藏的IFRAME中進行搜尋,然後将搜尋結果反映到Ajax元素上,以便将應用程式狀态恢複到當時的狀态。)
一個相關的觀點認為,使用動态頁面更新使得使用者難于将某個特定的狀态儲存到收藏夾中。該問題的解決方案也已出現,大部分都使用URL片斷辨別符(通常被稱
為錨點,URL中#後面的部分)來保持跟蹤,允許使用者回到指定的某個應用程式狀态。(許多浏覽器允許JavaScript動态更新錨點,這使得Ajax
應用程式能夠在更新顯示内容的同時更新錨點。這些解決方案也同時解決了許多關于不支援後退按鈕的争論。
進行Ajax開發時,網絡延遲——即使用者送出請求到伺服器發出響應之間的間隔——需要慎重考慮。不給予使用者明确的回應
[5],沒有恰當的預讀資料
[6],或者對XMLHttpRequest的不恰當處理
[7],都會使使用者感到延遲,這是使用者不欲看到的,也是他們無法了解的
[8]。通常的解決方案 是,使用一個可視化的元件來告訴使用者系統正在進行背景操作并且正在讀取資料和内容。
一些手持裝置(如手機、PDA等)現在還不能很好的支援Ajax; 用JavaScript作的Ajax引擎JavaScript
的相容性和DeBug都是讓人頭痛的事;
Ajax的無重新整理重載,由于頁面的變化沒有重新整理重載那麼明顯,是以容易給使用者帶來困擾――使用者不太清楚現在的資料是新的還是已經更新過的;現有的解決有:在相關位置提示、資料更新的區域設計得比較明顯、資料更新後給使用者提示等;
對串流媒體的支援沒有FLASH、Java Applet好;