以CC-BY-SA協議引自維基百科AJAX 文章(作者) |
AJAX即“Asynchronous JavaScript and XML”(异步的JavaScript與XML技術),指的是一套综合了多項技術的瀏覽器端網頁開發技術。Ajax的概念由Jesse James Garrett所提出[1]。
传统的Web应用允许用户端填写表单(form),当送出表单时就向Web伺服器发送一个请求。伺服器接收并处理传来的表单,然后送回一个新的网页,但这个做法浪费了许多带宽,因为在前后两个页面中的大部分HTML码往往是相同的。由于每次应用的沟通都需要向伺服器发送请求,应用的回應时间依赖于伺服器的回應时间。这导致了用户界面的回應比本機应用慢得多。
与此不同,AJAX应用可以仅向伺服器发送并取回必須的数据,并在客户端采用JavaScript处理来自伺服器的回應。因为在伺服器和浏览器之间交换的数据大量减少,伺服器回應更快了。同时,很多的处理工作可以在发出请求的客户端机器上完成,因此Web伺服器的负荷也减少了。
类似于DHTML或LAMP,AJAX不是指一种单一的技术,而是有机地利用了一系列相关的技术。虽然其名称包含XML,但实际上数据格式可以由JSON代替,进一步减少数据量,形成所谓的AJAJ。而客户端与服务器也并不需要异步。一些基于AJAX的“派生/合成”式(derivative/composite)的技术也正在出现,如AFLAX。
应用[]
- 運用XHTML+CSS來表達資訊;
- 運用JavaScript操作DOM(Document Object Model)来執行動態效果;
- 運用XML和XSLT操作資料
- 運用XMLHttpRequest為Agent與網頁伺服器進行非同步資料交換;
- 運用JavaScript技術来實現。
- 注意:AJAX與Flash、Silverlight和Java Applet等RIA技術是有區分的。
发展史[]
上个世纪90年代,几乎所有的网站都由HTML页面实现,服务器处理每一个用户请求都需要重新加载网页。这样的处理方式效率不高。用户的体验是所有页面都会消失,再重新载入,即使只是一部分页面元素改变也要重新载入整个页面,不仅要刷新改变的部分,连没有变化的部分也要刷新。这会加重服务器的负担。
这可以用异步加载来解决。1995年,JAVA语言的第一版发布,随之发布的的Java applets(JAVA小程序)首次实现了异步加载。浏览器通过运行嵌入网页中的Java applets与服务器交换数据,不必刷新网页。1996年,Internet Explorer将iframe元素加入到HTML,支持局部刷新网页。
1998年前后,Outlook Web Access小组写成了允许客户端脚本发送HTTP请求(XMLHTTP)的第一个组件。该组件原属于微软Exchange Server,并且迅速地成为了Internet Explorer 4.0[2]的一部分。部分观察家认为,Outlook Web Access是第一个应用了Ajax技术的成功的商业应用程序,并成为包括Oddpost的网络邮件产品在内的许多产品的领头羊。但是,2005年初,许多事件使得Ajax被大众所接受。Google在它著名的交互应用程序中使用了异步通讯,如Google讨论组、Google地图、Google搜索建议、Gmail等。Ajax这个词由《Ajax: A New Approach to Web Applications》一文所创,该文的迅速流传提高了人们使用该项技术的意识。另外,对Mozilla/Gecko的支持使得该技术走向成熟,变得更为简单易用。
优缺点[]
使用Ajax的最大优点,就是能在不更新整个页面的前提下维护数据。这使得Web应用程序更为迅捷地回应用户动作,并避免了在网络上发送那些没有改变的信息。
Ajax不需要任何浏览器插件,但需要用户允许JavaScript在浏览器上执行。就像DHTML应用程序那样,Ajax应用程序必须在众多不同的浏览器和平台上经过严格的测试。随着Ajax的成熟,一些简化Ajax使用方法的程序库也相继问世。同样,也出现了另一种辅助程序设计的技术,为那些不支持JavaScript的用户提供替代功能。
对应用Ajax最主要的批评就是,它可能破坏浏览器的后退功能[3]。在动态更新页面的情况下,用户无法回到前一个页面状态,这是因为浏览器仅能记下历史记录中的静态页面。一个被完整读入的页面与一个已经被动态修改过的页面之间的差别非常微妙;用户通常都希望单击后退按钮,就能够取消他们的前一次操作,但是在Ajax应用程序中,却无法这样做。不过开发者已想出了种种办法来解决这个问题,当中大多数都是在用户单击后退按钮访问历史记录时,通过建立或使用一个隐藏的IFRAME来重现页面上的变更。(例如,当用户在Google Maps中单击后退时,它在一个隐藏的IFRAME中进行搜索,然后将搜索结果反映到Ajax元素上,以便将应用程序状态恢复到当时的状态。)
一个相关的观点认为,使用动态页面更新使得用户难于将某个特定的状态保存到收藏夹中。该问题的解决方案也已出现,大部分都使用URL片断标识符(通常被称为锚点,即URL中#后面的部分)来保持追蹤,允许用户回到指定的某个应用程序状态。(许多浏览器允许JavaScript动态更新锚点,这使得Ajax应用程序能够在更新显示内容的同时更新锚点。)这些解决方案也同时解决了许多关于不支持后退按钮的争论。
进行Ajax开发时,网络延迟——即用户发出请求到服务器发出响应之间的间隔——需要慎重考虑。如果不给予用户明确的回应[4],没有恰当的预读数据[5],或者对XMLHttpRequest的不恰当处理[6],都会使用户感到厌烦[7]。通常的解决方案是,使用一个可视化的组件来告诉用户系统正在进行后台操作并且正在读取数据和内容。
支持[]
- 一些手持设备(如手机、PDA等)现在还不能很好的支持Ajax;
- 用JavaScript作的Ajax引擎,JavaScript的兼容性和DeBug都是让人头痛的事;
- Ajax的无刷新重载,由于页面的变化没有刷新重载那么明显,所以容易给用户带来困扰——用户不太清楚现在的数据是新的还是已经更新过的;现有的解决有:在相关位置提示、数据更新的区域设计得比较明显、数据更新后给用户提示等;
- 对串流媒体的支持没有FLASH、Java Applet好。
兼容性[]
JavaScript编程的最大问题来自不同的浏览器对各种技术和标准的支持。
XmlHttpRequest对象在不同浏览器中不同的创建方法,以下是跨瀏覽器的通用方法:
// Provide the XMLHttpRequest class for IE 5.x-6.x:
// Other browsers (including IE 7.x-8.x) ignore this
// when XMLHttpRequest is predefined
var xmlHttp;
if (typeof XMLHttpRequest != "undefined") {
xmlHttp = new XMLHttpRequest();
} else if (window.ActiveXObject) {
var aVersions = ["Msxml2.XMLHttp.5.0", "Msxml2.XMLHttp.4.0", "Msxml2.XMLHttp.3.0", "Msxml2.XMLHttp", "Microsoft.XMLHttp"];
for (var i = 0; i < aVersions.length; i++) {
try {
xmlHttp = new ActiveXObject(aVersions[i]);
break;
} catch (e) {}
}
}
AJAX支持的浏览器有:Internet Explorer、Chrome、Firefox、Opera、Konqueror及Mac OS的Safari。但Opera不支持XSL格式对象,也不支持XSLT[8]。
参考文献[]
- ↑ Ajax:網頁應用程式的新方法—Jesse James Garrett,最近存取日2007年11月7日
- ↑ 微軟XML Parser(MSXML)版本列表,最近存取日2007年11月7日
- ↑ Web设计10大错误(1999年)—Jakob Nielsen著
- ↑ Remote Scripting with AJAX, Part 2
- ↑ 延遲必死:預讀資料以降低延遲—JonathanBoutelle.com
- ↑ 不可靠網路下的非同步要求—Harry Fuecks著,2005年2月
- ↑ 小朋友們聽著, AJAX不怎麼酷—Marcus Baker著,2005年6月3日
- ↑ Opera 9支援的網頁規格—XSLT, XPath, and XSL-FO部分論及不支持XSL-FO與XSLT,最近存取日2007年11月7日
- Ajax: A new approach to web applications --JJ Garrett - 2005年
工具[]
- ASP.NET AJAX Extension(開發階段時代號Atlas),微軟AJAX工具箱。
- jQuery,開源JS框架,寫得更少,做得更多。
- Dojo工具箱,AJAX/DHTML工具箱。
- Prototype,開放源代碼框架。
- Buffalo Web Remoting(based on prototype)
- openrico JS UI component(based on prototype)
- PHPRPC,開放源代碼多語言支持的跨平台的安全的Web遠程過程調用框架,讓Ajax編程更容易。
- Sajax,簡單AJAX工具箱
- Rialto,Rich Internet AppLication TOolkit.
- MochiKit一個自稱AJAX的輕量級js庫,支持Json。
- OpenLaszlo原本專注在Flash作為表現層的Laszlo將方向轉至AJAX。
- script.aculo.us為Ruby on Rails量身打造的AJAX函式庫,跨平台支援。
- Rico知名的開源碼的AJAX函式庫,跨平台支援。
- DWR Web Remoting
- qooxdoo JS UI component(C/S Style)
- jsLINB完全OOP,帶有線程模擬的ajax RIA框架。
- GWT Google開源框架。
- Quicknet一個能提供安全資料傳輸的AJAX系統架構。
图书[]
- 《Ajax基础教程》,Foundations Of Ajax中文版,人民邮电出版社图灵公司出版。ISBN 7-115-14481-8
- 《Ajax实战》,Ajax in Action中文版,人民邮电出版社图灵公司出版。ISBN 7-115-14717-5
- 《Ajax高级程序设计》(第二版),Professional Ajax,人民邮电出版社图灵公司出版。
- 《Head First Ajax》O'Reilly出版社
- 《Ajax實戰手冊》碁峰ISBN 986-181-036-6
- 《Ajax技術手冊》碁峰ISBN 986-181-019-6
參見[]
- Google Web Toolkit是一個前端使用JavaScript,後端使用Java的AJAX framework,提供WYSIWYG設計介面。
- jQuery用于简化AJAX开发的Javascript函式庫。
- Prototype javascript|Prototype AJAX函式庫。
- Yahoo! UI Library is a set of utilities and controls, written in JavaScript, for building richly interactive web applications using techniques such as DOM scripting, DHTML and AJAX.
- Xajax知名的開源碼開發AJAX用PHP函式庫。
- ZK,开放源代码AJAX/XUL框架,JAVA專用。
- ASP.NET AJAX,由微軟專為ASP.NET應用程式所開發的AJAX基礎架構。
- Web 2.0,一种新的互联网概念
- 推送技术,一种服务端主动通知用户的技术