您的位置:IT爆料网 > 互联网

你真正的了解Ajax?Ajax技术简述

发布时间:2023-01-20 06:55:17  来源:互联网     背景:

 

Ajax技术是目前在浏览器中通过JavaScript脚本可以使用的所有技术的集合。Ajax并没有创造出某种具体的新技术,它所使用的大多数技 术都是在很多年以前就已经存在了,然而Ajax以一种崭新的方式来使用所有的这些技术,使得古老的B/S方式的Web开发焕发了新的活力,迎来了第二个春天。

具体来说,Ajax基于下列这些核心技术:

XHTML:对应W3C的XHTML规范,目前是XHTML1.0。
CSS:对应W3C的CSS规范,目前是CSS2.0。
DOM:这里的DOM主要是指HTML DOM,XML DOM包括在下面的XML中。
JavaScript:对应于ECMA的ECMAScript规范
XML:对应W3C的XML DOM、XSLT、XPath等规范。
XMLHttpRequest:对应WhatWG的Web Applications1.0规范(-apps/current-work/)的一部分

可以看出,除了XMLHttpRequest以外,所有的技术都是目前已经广泛使用,得到了广泛理解的基于Web标准的技术。而 XMLHttpRequest虽然尚未被W3C采纳,其实已经是一个事实上的标准了。几乎所有主流的浏览器,例如IE、Firefox、 Netscape、Opera、Safari全部都支持这个技术。所以Ajax就是目前做Web开发最符合标准的技术。上述的所有技术都已经可以在浏览器 中使用,因此用户不需要安装任何额外的软件(只需要有一个浏览器,例如IE),就可以运行任何符合标准的Ajax应用。这对于Ajax技术的普及、降低 Ajax应用部署和维护的成本是非常重要的。

此外,随着浏览器的发展,更多的技术还会被添加进Ajax的技术体系之中。例如,目前Firefox浏览器的最新版本已经可以直接支持矢量图形格式 SVG。Firefox已经可以支持JavaScript 2.0(对应ECMAScript 4.0规范)中的E4X(JavaScript的XML扩展)。Firefox、Opera、和Safari浏览器还可以支持Canvas(也是Web Applications1.0规范的一部分),网上已经有人开发出了使用Canvas技术制作的3D射击游戏的演示。但是因为这些技术目前还没有得到市 场占有率最高的IE浏览器的支持,目前只能被应用在一些有限的场合(例如,在企业/机关内部,可以要求用户只使用Firefox浏览器)。

在上述的这些Ajax的核心技术中,最核心的技术就是XMLHttpRequest。它最初的名称叫做XMLHTTP,是微软公司为了满足Web开发 者的需要,1999年在IE5.0浏览器中率先推出的。后来这个技术被上述的规范命名为XMLHttpRequest。它正是Ajax技术所以与众不同的 地方。简而言之,XMLHttpRequest为运行在浏览器中的JavaScript脚本提供了一种在页面之内与服务器通信的手段。页面内的 JavaScript可以在不刷新页面的情况下从服务器获取数据,或者向服务器提交数据。而在这个技术出现之前,浏览器向服务器提交数据只能通过HTML 表单的提交,从服务器获取数据只能通过点击一个超链接,这些操作一般都会带来一次全页面的刷新。

XMLHttpRequest的出现为Web开发提供了一种全新的可能性,甚至整个改变了人们对于Web应用由什么来组成的看法。在这个技术出现之 前,由于技术上的限制,人们认为Web应用就是由一系列连续切换的页面组成的。因此整个Web应用被划分成了大量的页面,其中大部分是一些很小的页面。用 户大部分的交互都需要切换并且刷新整个页面,而在这个过程中(下一个页面完全显示出来之前),用户只能呆呆地等着,什么事都做不了。这就是我们所习以为常 的Web应用,在10年以前就是这个样子。然而XMLHttpRequest技术的出现使得我们终于可以打破这种笨拙的开发模式,以一种全新的方式来做 Web开发,为用户提供更好的交互体验。大量的探索者(自豪的说,也包括笔者在内)以XMLHttpRequest技术为基础,将一些古老的Web技术重 新包装整合。经过了多年的不懈努力,终于在2005年开花结果。在这一年的2月,出现了一个新的术语Ajax,来描述这样一类的技术和开发方式。

与传统的Web开发不同,Ajax并不是以一种基于静态页面的方式来看待Web应用的。从Ajax的角度看来,Web应用仅由少量的页面组成,其中每 个页面其实是一个更小型的Ajax应用。而一些简单的Ajax应用,例如一个简单的RSS阅读器,甚至只有一个页面。每个页面上面都包括有一些使用 JavaScript开发的Ajax组件。这些组件使用XMLHttpRequest对象以异步的方式(就是不需要打断用户操作的后台方式)与服务器通 信,从服务器获取需要的数据后,使用DOM API来更新页面中的一部分内容。因此Ajax应用与传统的Web应用的区别主要在3个地方:

1. 不刷新整个页面,在页面内与服务器通信。
2. 使用异步方式与服务器通信,不需要打断用户的操作,具有更加迅速的的响应能力。
3. 应用仅由少量页面组成。大部分交互在页面之内完成,不需要切换整个页面。

由此可见,Ajax使得Web应用更加动态,带来了更高的智能,并且提供了表现能力丰富的Ajax UI组件。这样一类新型的Web应用叫做RIA(Rich Internet Application)应用。除了Ajax,还包括有Flash等等技术。

与1990年代末的DHTML相比,Ajax更加强调符合真正的Web标准的开发方式。Ajax对于现有的基于Web标准的技术的利用程度比 DHTML高出了很多。而DHTML当初昙花一现,随后声名狼藉,最终彻底失败的最大原因就在于其开发者大多不重视基于真正的Web标准来做开发。

DHTML其实是浏览器大战的时代微软和Netscape为了吸引眼球而制造的一个名词,并没有得到W3C的认可。并且经常被开发人员滥用,制造出一 大堆不符合真正的Web标准的JavaScript脚本和HTML标记,常常只能运行在某种特定的浏览器中(主要是IE)。DHTML总是过于注重各种花 哨的视觉效果,而Ajax所最为关注的问题则是真正改善Web应用可用性,这正是Ajax技术诞生的使命,甚至也正是JavaScript脚本语言诞生的 使命。

跨浏览器自然是Web应用可用性的重要组成部分,只有基于真正的Web标准来做开发,才有可能跨浏览器为用户提供一致的交互体验。而跨浏览器仅仅是基 于真正的Web标准做开发的一个原因。另一个原因是,唯有这样,才能建造出向后兼容的Web应用。向后兼容的意思就是我们今天建造的Web应用,当明天用 户都使用浏览器的新版本(例如IE 7.0)之后,不必做任何修改就能够直接运行在这些新版本上。这样可以降低Web应用的维护成本,并且对于改善可用性、使用户获得更好的交互体验也会很有 帮助。做过多年Web开发的开发者都知道,以前专门为IE 5.0开发的Web应用,不加以修改和重新测试就运行在IE 6.0上是很困难的。在这里就是没有做到向后兼容,Ajax技术会使得这些问题都不再存在。此外,基于真正的Web标准做开发,才能充分地利用Web标准 发展的各项成果(例如上述的SVG、E4X等符合标准的技术),利用最先进的技术为用户提供更好的交互体验。

Ajax技术的背后有两个推动力:Web标准的成熟、软件可用性和交互设计理论的成熟。在软件的可用性方面,除了一些通用的可用性和交互设计理论之外 (这方面的经典著作包括《About Face 2.0》中文版、《面向使用的软件设计》等等),Web应用的可用性(Web usability)也是国外非常热门的一个研究领域,主要侧重于研究如何提高Web网站的可用性。美国在这个领域有着非常深入的研究,并且对于一些公共 机构网站的可用性还有相关的法律条款来约束(Section508,508条款,于2001年6月21日成为美国的法律,直接影响了联邦部门和一些代理机 构,还有为他们服务的网页设计师。这条法律也适用于政府投资项目和任何采用了该法律的州)。对于这些网站,如果无法达到条款上的一些可用性要求,网站经营 者就违法了。如果是开发公司无法达到这些要求,就别指望从联邦政府手中拿到这些项目。

为了对如何提高Web应用的可用性做出指导,W3C在20世纪90年代建立了Web Accessibility Initiative(WAI),致力于为网站建造者提供实现可访问性(与可用性同义)的方法和策略()

Web可用性方面的经典著作包括《网站重构》。

综上所述,可以认为Ajax就是Web标准和Web应用的可用性理论的集大成者。它极大地改善了Web应用的可用性和用户的交互体验,最终得到了用户和市场的广泛认可。所以可以说,Ajax就是用户和市场的选择。

目前Ajax已经成为了Web应用的主流开发技术,大量的业界巨头已经采纳并且在大力推动这个技术的发展。最近的动态包括:

1. IBM、Oracle、Yahoo!、BEA、RedHat、Novell等页界领先的公司启动了Open Ajax项目。致力于为Ajax开发建造先进强大的的开发工具。

IBM在2月底已经发布了Open Ajax项目的Ajax Toolkit Framework(ATF)1.0,是一个基于Eclipse IDE的Ajax开发工具。

2. 微软开发了自己的Ajax框架Altas,不过主要是和服务器端他们自己的ASP.NET框架配合工作。

3. Sun虽然行动迟缓,但是也将Ajax技术列入了J2EE的blueprint(蓝图)中,作为J2EE技术的有益的补充。

除了上述这些公司之外,Google公司不可不提,因为正是他们率先采用Ajax技术建造出了一大堆非常出色的应用,才将Ajax技术引到了聚光灯下。Google公司建造的Ajax应用包括Google Maps、GMail、Google Suggest等等,其中公认最优秀最复杂的Ajax应用是Google Maps。由于完全基于Ajax技术来建造Google Maps的界面,Google Maps提供了远远超越其竞争对手的地图服务的交互体验。如果说Google后台的地图技术并不存在巨大优势的话,那么Ajax技术和优秀的交互设计成为了他们压倒竞争对手的最后一根稻草。最终使得Google Maps脱颖而出,获得了用户的青睐。

我们可以对比一下微软前后的两个地图服务就可以看出差别。

微软公司所提供的旧的地图服务:。是传统Web应用的代表,性能很差而且极其难用。

微软公司所推出了新的地图服务:。新的地图服务包括这个网站上的很多其他服务完全基于Ajax技术来建造,获得了极好的可用性。这个新的地图服务可以看作是在Google推出了Google Maps服务之后,微软公司痛定思痛的产物,在很多地方模仿了Google Maps。

Ajax的典型应用除了Google Maps,还有微软的Windows Live、Yahoo!的Flickr等等。此外国内新浪的blog也使用了一些Ajax的技术。

 


本文标题:你真正的了解Ajax?Ajax技术简述 - 互联网
本文地址:www.itbaoliao.com/hlw/20125.html

返回网站首页

本文评论
中央宣传部约谈腾讯网易等游戏企业 防止未成年人沉迷网络游戏
【TechWeb】9月8日消息,据新华社消息,中央宣传部、国家新闻出版署有关负责人会同中央网信办、文化和旅游部等部门,对腾讯、网易等重点网络游戏企业和游戏账号租售平台、游戏直播平台进行约谈。约谈强调,各网络游戏企业和平台要严格落实通知各项...
日期:12-25
北京现共享健身仓 网友:里面会不会都是汗臭味啊
日前,觅跑共享健身仓亮相北京街头,引不少市民驻足围观。...
日期:11-08
华为Mate 9发布会 视频回顾!90秒精彩浓缩!(视频)
华为Mate 9发布会 视频回顾!90秒精彩浓缩!(视频)今天下午,华为在上海召开发布会,发布了Mate 9家族的三款产品,分别是:Mate 9、Mate 9 Pro以及保时捷版Mate 9。点击观看视频Mate 9采用的是5.9英寸1...
日期:11-20
提速30%全新首页 UC 3.0 for WP发布
随着全球各大手机厂商对于Windows Phone支持力度的不断加大,推出的机型不断增多,Windows Phone手机也得到了越来越多用户的喜爱。国际知名市场研究机构Gartner最新发布的2013年第一季度的全球移动设备研究报告中就表示...
日期:11-18
窝窝团收购55.com域名 称不做团购导航
新浪科技讯 7月11日下午消息,团购网站窝窝团CEO徐茂栋今日在新浪微博披露,其已经收购55.com域名,但他强调不会涉足团购导航业务。目前55.com域名运营的是一个团购导航网站,窝窝团的域名则为55tuan.com。徐茂栋表示,本次购...
日期:12-12
希腊神话网游《Heva》台服官网上线
以希腊神话中登场的象征青春和春天的女神Heva为主题的休闲网络游戏《HEVA Online》台服形象官网上线,预计第三季度正式和玩家见面,官网中富含大量的动作影片及动画,强力展示《HEVA Online》的动感与机关特色...
日期:11-22
网传小米仓库起火 官方回应:不是小米的仓库 货品有受损但有保险
【TechWeb】6月7日消息,日前,一间位于长沙天心区芙蓉南路四段的湖南南塘仓储物流公司所属仓库起火,有网友称,这个仓库归属于小米,起火导致库存烧光,影响到华南618的备货。对此,小米公关总经理王化回应称,不是小米的仓库。另外,对于网...
日期:10-10
ios5开放下载 苹果ios5升级详细教程
自动升级与手动升级在做好万全的准备工作之后,就可以开始进行固件升级了。具体的升级方法分为自动升级和手动升级两种,下面就让小编为大家分别介绍一下两种不同升级方法的具体操作步骤。一、自动升级自动升级的操作步骤非常简单,用户只需要将设备与电...
日期:11-11
酷我星吧网日前获第二轮550万美元风投
消息人士透露,互联网娱乐公司北京亿览日前完成第二轮550万美元融资,此次投资由启明创投及其伙伴Ignition Partners领衔,另外两家企业也参与了投资。   《每日经济新闻》昨致电亿览,该公司CEO雷鸣并未否认这...
日期:11-03
最淘网陈华:代金券模式能弥补团购缺陷
现在又多了一个新的优惠方式:购物前先去代金券聚合平台买代金券,再享受优惠,你会考虑吗?作为一种常见促销方式,代金券因其限制较多、操作不便、使得这一市场非常零散,酷讯网创始人陈华想把这个市场聚合起来,创办了最淘网,引导用户网购前先来最淘网淘代金券,获得更多优惠。那么最淘网怎样解决上述代金券弊病?去听听陈华怎么说。...
日期:12-26
在微博上定制一瓶属于你的可口可乐
文│本刊记者 孟佳在这个夏天,可口可乐在全国掀起了一场“换装”热潮。可口可乐利用互联网上的热门词汇推出了一系列“昵称瓶”新装,诸如“文艺青年”、“小清新&...
日期:11-09
Ti5落幕EG登顶 ti5冠军奖金4000万!
Ti5落幕EG登顶 ti5冠军奖金4000万! 《DOTA2》,是脱离了其上一代作品《DOTA》所依赖的War3的引擎,由《DOTA》的地图核心制作者IceFrog(冰蛙)联手美国Valve公司使用他们的Source引擎研发的、Valve运营,完美世界代理(国服),韩国NEXON代理(韩服)的多人联机对抗RPG。第五届《DOTA2》国际邀请赛TI5在西雅图Key Arena球馆落幕,来自美国的EG以3:1击败了中国的CDEC获得冠军,夺得超650万美金的冠军奖金。中国队伍CDEC和LGD则分别获得了亚军和...
日期:11-26
2019支付宝集五福玩法攻略 支付宝怎么快速集福卡
今年的支付宝集福卡玩法包括大众熟悉的“AR扫福、森林浇水和庄园喂小鸡”得福卡的主玩法,今年还将新增答题得福卡这一种方式,题目将以安全教育为主。...
日期:10-23
Quick拍王鹏飞:做二维码市场的先驱者
专注于二维码服务的Quick拍是一款最受欢迎的二维码识别生成软件,Quick创始人王鹏飞认为中国的二维码市场刚刚起步,他希望二维码应用能在三年内达到普及。他的愿望能否实现?本期Talks访谈,走进王鹏飞的二维码理想。...
日期:11-14
甘薇弃优先分配权 此前曾提出39.83亿离婚索偿
3月4日消息 ,美国当地时间3月2日,贾跃亭正式向美国加州中区法院提交最新版破产重组披露声明,至此所有破产重组相关文件均已提交完成。...
日期:11-28
lols8赛季众星之子索拉卡 s8奶妈天赋符文加点出装攻略
LOL每个赛季天赋改动都很大,S8赛季的符文系统也将进行改动,所以小编在这里为大家带来奶妈S8赛季的天赋符文加点以及出装攻略,我们会保持更新最新的内容!...
日期:12-31
乐蜂网涉嫌贩假遭调查 食药监局称正在核实证据
乐蜂网涉嫌贩假遭调查 食药监局称正在核实证据【TechWeb报道】4月14日消息,北京市食药监管局稽查总队近日接到消费者关于“唯品乐蜂涉嫌贩假”的投诉后,已正式立案,并组织执法人员对其仓库现场调查。北京市食药监...
日期:11-06
王者荣耀裴擒虎出装攻略 裴擒虎六神装线路
王者荣耀裴擒虎出装攻略分享,裴擒虎是新推出的英雄,是很强势的战士,很多小伙伴还不清楚裴擒虎如何出装,下面就来看看裴擒虎六神装线路吧。...
日期:01-09
沉淀三年再度起航 莉莉丝发布2款自研、4款代理游戏
【TechWeb报道】9月9日消息,如果把发布会称为硬件领域的盛会,那么沉寂三年后的莉莉丝打造了一场游戏盛宴。这次莉莉丝的“兜里”揣满了砝码,准备在趋于饱和的游戏市场上开启“大招”模式。9月8日, 莉莉丝在“Next Game”为主题的发布会上发布了两款自研产品以及四款各具特色的代理产品,莉莉丝更是向外界透露公司正式转入研运一体。...
日期:01-13
国家大剧院古典音乐频道官方入驻网易云音乐
8月29日,国家大剧院古典音乐频道官方入驻网易云音乐的消息,让网易云音乐古典音乐发烧友们颇为激动。“网易云音乐简直业界良心,从来不忽视任何一个用户群体,古典音乐内容也越来越丰富了。”很多用户在评论区表达兴奋之情。...
日期:12-17