嘟嘟老窝-ajax

来源:百度文库 编辑:神马文学网 时间:2024/04/20 05:46:58
 

嘟嘟老窝

上帝给了我一双黑色的眼睛,我却用它来翻白眼......

导航

  • Index
  • MyKMS
  • MyOpml
  • TagCloud
  • Search
  • RSS
  • Admin

Think in AJAX(三) —— AJAX框架汇总

此文原出于AJAX Patterns网站的一篇《Ajax Frameworks》的wiki文章,很早前我就注意到,后来在国内也有人翻译了,不过最近发现此wiki还是在不断添加维护中,截止此文发布前,作者又添加了好几个新诞生的AJAX开发工具,所以我决定重新翻译一遍,并且时常注意原文发布状态,一有新的内容立马也翻译过来,做到同步:)

此翻译稿很大一部分内容出自国内出现的那个先前版本,我只是对新加入的几项进行了翻译,并且对我熟悉的产品项着重介绍了一下,以后我会抽时间收集文中提到AJAX工具相关的文章,尽量将内容介绍和功能点评做到全面详细点。所以请关注和准备用AJAX做开发的朋友关注这篇文章,我会时常更新的。原文因为是由一个wiki系统维护,所以在所难免出现参差不齐,风格上也有不统一的情况,翻译时我也是参照原文原封不动的挪了过来,以后我会抽时间改良下。

目录

1 Pure Javascript: Application Frameworks
1.1 Bindows
1.2 BackBase
1.3 DOJO
1.4 Open Rico
1.5 qooxdoo
1.6 Tibet
1.7 AJFORM
2 Pure Javascript: Infrastructural Frameworks
2.1 AjaxCaller
2.2 Flash JavaScript Integration Kit
2.3 Google AJAXSLT
2.4 HTMLHttpRequest
2.5 Interactive Website Framework
2.6 LibXMLHttpRequest
2.7 MAJAX
2.8 RSLite
2.9 Sack
2.10 Sarissa
2.11 XHConn
3 Server-Side: Multi-Language
3.1 Cross-Platform Asynchronous INterface Toolkit
3.2 SAJAX
3.3 Javascipt Object Notation (JSON) and JSON-RPC
3.4 Javascript Remote Scripting (JSRS)
3.5 Bitkraft for ASP.NET
4 Server-Side: Java
4.1 WebORB for Java
4.2 Echo 2
4.3 Direct Web Remoting (DWR)
4.4 SWATO
4.5 AJAX JSP Tag Library
4.6 AJAX Java Server Faces Framework
5 Server-Side: Lisp
5.1 CL-Ajax
6 Server-Side: .NET
6.1 WebORB for .NET
6.2 Ajax.NET
6.3 ComfortASP.NET
6.4 AjaxAspects
7 Server-Side: PHP
7.1 AjaxAC
7.2 JPSpan
7.3 XAJAX
8 Server-Side: Ruby
8.1 Ruby On Rails

Thinking in AJAX(二) —— 基于AJAX的WEB设计

一、AJAX最值得称赞的是异步交互,而不是无刷新

很多人都看好AJAX无刷新的技术,以至于认同AJAX就是用来做无刷新的。这个认识是错误的,什么是无刷新?无刷新就是页面无需重载,那什么又是异步交互?异步交互就是一个简单的多线程,当你在一个blog里看文章时,同时也可以利用AJAX进行无刷新的回复提交,看起来虽然也是无刷新,但这里最重要的是异步,即你能一边看文章,一边又能向服务器提交你的回复信息,利用好这个异步,才能算是掌握了AJAX的精髓。很多场合,无刷新是呈现给用户的视觉体验,而异步交互却是默默无闻的工作在台后,这种情况导致大多数人的错误理解了AJAX的权重之分。

二、推荐在WEB上轻量级的应用AJAX



著名的图片存储网站Flickr利用AJAX可谓出神入化。我之所以这么说,是因为我认为Flickr深知AJAX的利与弊,并且牢牢抓住自己的网站的功能特点,并没有因AJAX而AJAX,而是架驱于技术至上,让AJAX融于网站之中,为网站提供了更好的功能服务。如Flickr中无论是在多图列表页面还是单图详细页面,修改图片的标题和描述都应用了AJAX技术,让用户无需跳转到单独的编辑页面中,编辑后单击保存,亦使用了异步交互的方式进行数据提交,这时,页面上显示一个Loading字符外,其他部分不受任何影响,可谓太贴心的服务。

再如基于Tag的专业Blog搜索服务商Technorati也使用了AJAX,在搜索某个Tag时,页面主导部分会即刻显示所有Technorati数据库中查询到的数据条目,在左边的侧边栏上会显示两个Loading图标,过一会儿,这两个Loading就会显示具体的内容了,显示的是此Tag相关的Flickr的图片和书签服务网站(Furl&del.icio.us)的链接,因为这两部分内容是取自其他网站,如果由服务器统一先取得数据在一同显示到页面时,会受到网速影响而变慢,通过AJAX的异步交互方式首先立即显示本地数据,然后由客户端去和Flickr、Furl、del.icio.us打交道分别取得它们的数据,即节约了流量带宽又不影响用户访问速度,可谓高明。

通过以上两个国外成功应用AJAX的网站,我们发现他们都使用的是轻量级的AJAX,就是那种交互简单,数据较少的操作。这也符合AJAX的本意,虽然像www.backbase.com和bindows都在RIA上有惊人的表现能力,但是速度慢、搜索引擎支持不好、开发难度大等毛病还是无法让用户满意的,请记住:AJAX的最终目的是为了提高用户体验,为了方便用户交互,而不是因技术而技术的。

三、AJAX的MVC架构设计

很多人认为在成熟的框架中应用AJAX会破坏框架的完整性,比较常见的说法有三层架构的WEB应用中破坏MVC模式,其实不然。MVC的理论我就不多说了,经典的那三个层、五条线大家都很熟悉,在WEB应用中,因为浏览器/服务器固有的这种请求/响应的断开式网络通讯模式,决定了在Model层无法实现主动向View层发出数据更新事件,所以一般常见的成熟MVC框架中都将经典MVC理论稍作修改:由Model层处理完业务后通知Control层,然后由Control层承担向View发送数据更新的义务。但是AJAX天生具有监听功能,AJAX实现异步响应的那个OnReadyStateChange事件就具有在客户端程序中才会有的事件监听功能。现在想来,利用AJAX实现的MVC模型有如下图这样:

理想化的设计如下所示:

  • 三层对应的文件对象:view.jsp(视图)、action.do(控制器)、model.java(模型)
  • view.jsp是用户看到的界面,并通过内置的AJAX对象异步方式给action.do发送请求,AJAX.OnReadyStateChange开始监听
  • action.do接收到view.jsp发过来的请求(GET或者POST方式),通过Request判断后发送给相应的业务/数据模型model.java
  • model.java开始执行业务操作,执行完毕直接给view.jsp页面发送数据更新的通知,这个通知的消息有可能是XML封装的数据,也有可能是一段文本,甚至是一段HTML代码,当然,既然用MVC,不推荐有Model发送HTML,推荐还是用XML封装业务数据即可。
  • view.jsp页面中AJAX对象的OnReadyStateChange接收到了数据更新通知,根据实际情况用DOM进行页面呈现更新。
通过以上几步一气呵成,一个典型的基于MVC的三层交互就完成了。当然,熟悉WEB下的MVC框架的用户,如熟悉Struts的Java开发人员可能不习惯由Model层给View直接发送数据更新通知,那咱们也可以转变一下,Model层业务处理完毕将更新通知先发送给Control,由Control去通知View亦可。

注:全文完

Thinking in AJAX(一) —— AJAX - X

众所周知,异步交互、JavaScript脚本和XML封装数据是AJAX的三大特征。其实,在实际应用中,不需要牢牢套死这三条大律,在我看来,AJAX - X,即去掉用XML封装数据,也不失为一种好的设计思路,如果应用恰当,更显轻盈步伐和巧妙思路。

一般读取AJAX返回的XML结构的数据时使用XMLHttp的responseXML对象属性,同时,XMLHttp也提供了另外一个属性,即ResponseText,通过这个属性,XMLHttp可以接受来自服务器的文本结构的字符串信息。去掉XML的AJAX可以使用ResponseText这个对象属性,很灵活的操控返回数据的格式,可以自定义格式,比如我通常喜欢用c语言的那种文件流方式定义返回的字符串结构,有文件头和具体的文件信息实体,文件头分为状态信息以及文件字符长度,我摒弃了文件字符长度的定义,规定死接受的ResponseTex字符串中的第一位为状态码,比如设定常量值0表示一起正常,非0的数字表示不正常,甚至有错误等。如果有非0值,程序自动取第二位起到257位(长度为256)的字符串组成为状态信息,从258位开始到末尾的字符串就是服务器返回的正常结果信息。
substring(0,1)取状态码
substring(1,256)取服务器错误信息(错误信息不够256位用空格补齐,取到数据后进行Trim处理)
substring(256,末尾)取服务器返回的数据信息
三次substring即完成了一个简单但完整的交互工作。比起XML解析组件来说要快的多。

用ResponseText比封装为XML处理数据快和简单是一个原因,另一个原因是可操控性更大更灵活,打开Google Suggest,在搜索框输入字符可以给你给出拼写提示,Suggest就是应用了AJAX技术,不过它在从服务器返回数据时并没有使用XML封装,也没有自定义ResponseText格式,而是直接将返回代码组织成js脚本,通过浏览器返回后直接执行,如eval(XMLHttp.ResponseText)这样的方式进行执行,http://www.google.com/complete/search?hl=en&js=true&qu=ajax 通过这个链接你可以看到Suggest利用AJAX得到的返回数据,此页面是在Google Suggest的搜索框中输入"AJAX"后得系统动态返回的数据。

sendRPCDone(frameElement, "ajax", new Array("ajax", "ajax amsterdam", "ajax fc", "ajax ontario", "ajax grips", "ajax football club", "ajax public library", "ajax football", "ajax soccer", "ajax pickering transit"), new Array("3,840,000 results", "502,000 results", "710,000 results", "275,000 results", "8,860 results", "573,000 results", "40,500 results", "454,000 results", "437,000 results", "10,700 results"), new Array(""));
浏览器段拿到这段代码后直接eval就可以了,至于sendRPCDone这个函数,那当然得实现定义后并装载到页面中啦。XMLHttp这个名字以XML开头,让很多人禁锢了思想和创意,完全抛弃X,你也可以做出纯AJAX的实例来。

当然,对于大型系统来讲,为了保持数据接口的一致和整齐,还是用XML来传递更严谨更统一点,听说微软已经发起了重写XML Parse组件的号召,估计下一个版本的XMLHttp还是DOMParser还是MSXML2.DOMDocument都会大大提高效率,减少资源占用的。

注:全文完

将OPML中的Blogger快速推荐到特色中文Blogger

中文网志年会准备的如火如荼,并提倡大家通过del.icio.us推荐自认为有特色的Blogger,这个方法很好,在我订阅的Rss中有很多Blogger我都想推荐,可惜一个一个添加太麻烦了,灵机一动就做了这么一个小工具。

只要使用Rss的人一般都会订阅自己认为价值高有特色的Blog,所以参考自己的opml文件进行推荐是最方便的,我这个小工具就是通过Bloglines的opml文件自动罗列出你订阅的所有Feed,然后点一下按钮就会自动添加Blog地址到del.icio.us下,并加注cnbloggercon这个标签

使用方法:

  1. 先复制下这个输入框内的所有代码
  2. 打开BlogLines首页(其他页面亦可,但是不要用那个feed阅读页面,因为这个页面是个框架页面,懒得再从代码上修改支持框架了)
  3. 把1中拷贝下来的代码粘贴到当前Blogline页面的地址栏中,拍个回车就耐心等着吧,如果弹出del.icio.us的登录框,输入del.icio.us的帐号和密码即可。
  4. 等页面Load完就能看见opml文件中所有的feed列表,有一个Add Blogger按钮,点击就能添加到del.icio.us中了,注意,这里使用的是iframe,所以点击后应该在地址栏能看见有Load的进度,等进度100%了在点击下一个,页面的右上角能看见那个iframe窗口,内容就是发送添加书签命令给del.icio.us后得到的反馈结果。

实现方法其实很简单,主要使用了XMLHttpRequest远程从http://www.bloglines.com/export这个url中读取到opml文件,并通过DOM对这个xml文档进行遍历,找出所有有效节点并罗列出来。往del.icio.us里添加书签我用iframe实现的,用AJAX当然最好,只是跨域问题实在没办法解决了,这个小工具用了Johnvey Hwang的客户端代理技术,即通过javascript:命令结合url实现欺骗性质的跨域操作,但这也只能跨一个域,向我这个即用Bloglines又用del.icio.us,实在没办法了,只能用iframe了。

当然,你必须是del.icio.us和bloglines的注册用户,最好都已经保存cookie在当前你操作的机器上,不然可能会出现问题。目前只支持BlogLines的feed,对于其他用户,比如toPim用户,只要用了规范的opml格式,都能实现的。浏览器我也测试了,IE和Firefox都没问题

源文件只有一个JS文件:http://www.duduwolf.com/test/opml2blogger.js

注:全文完

极力推荐一个del.icio.us书签浏览小工具

介绍

名称:del.icio.us direc.tor
网址:http://johnvey.com/features/deliciousdirector/
介绍:del.icio.us direc.tor是一个用来查询用户从del.icio.us收录的网摘得快速浏览工具,这个工具基于AJAX技术,无须安装客户端(比那个tagSense要好的多了),界面和易用性非常好(看我的截图)。

功能:

  • 快速抓取del.icio.us中的所有链接,测试数据为12000条。
  • 具有本地搜索功能,本地搜索是指发送命令不经过网络,全部从已打开的浏览器里快速响应
  • 搜索支持tag和description,经我测试连描述和标题中的中文也支持,这是del.icio.us一直没有解决的问题
  • 最棒的还是对tag的支持,可以在选择定某个tag后快速列出相关tag,一共支持4级
  • 可以从列表中直接点击Edit对书签进行修改操作
  • 排序、排序,可以对tag、title、postTime进行排序,而且速度非常快

安装:

  1. 将这个链接加入到浏览器的快捷书签上,就像del.icio.us的post书签一样的添加方法 del.icio.us direc.tor
  2. 打开del.icio.us随便进入一个页面(这是必须,当页面的url不属于del.icio.us时无法执行)
  3. 这时浏览器可能会出现无响应,请不要急于关闭,这表明程序正在从del.icio.us中将你的书签全部下载到本地,请耐心等待
  4. 如果弹出登录框,输入del.icio.us的帐号密码即可(如果你没有del.icio.us的帐号那就点这个看看demo吧)
  5. 等待几秒钟(视你的书签数量不等)后页面将装载完毕,OK!输入一个查询或者点击tag列表进行享受性的书签浏览吧

其他:

搜索上支持三种方式:
  1. t:——这个用来搜索tag,如“t:blog”
  2. d:——这个用来搜索标题和描述,支持中文,如“d:书签”
  3. -t|d|keywords——用"-"号可以实现不包含查询,如要查询不包含"blogchina",即“-blogchina”
  4. 直接输入关键字就从url、title、description三个字段中进行查询

遗憾:

  • 本工具只支持IE和FireFox浏览器,对于小部分的Safari用户,因为Safari本身不支持javascript端的XSLT,所以无法使用
  • 搜索输入框实现了按键响应,即从搜索框中每次敲击键盘,就进行一次查询,这样虽然看似方便,但对于大量书签的用户,会产生片刻的输入拖延和停顿,我的机器是xp2500,也许高配置的机器操作时感觉会好点
  • 目前打开一次这个工具就需要重新从del.icio.us的服务器上下载所有书签,所以显得不够即时,这也没办法,浏览器本身不支持数据的脚本对数据的本地保存
  • 没有提供对tag的修改功能,其实通过那4个relate tag列表,已经给用户提供了非常良好的tag视察功能,如果用户能通过列表找到tag的不足进行即时修改岂不更好?

原理:

这项技术基本上是靠AJAX实现,即利用javascript和xmlhttprequest进行异步的数据交互,不过这其中和以往的AJAX有一点小差别,那就是这个小工具利用的是一个叫做client-side web service broker的技术,具体分析见我下一段,除过AJAX,在数据交互上还利用了服务端的XMLHttpRequest组件,这也属于一个关键应用。至于操作时的无刷新更改列表数据这就全靠javascript了,对tag相关性的检索、书签的检索以及列表排序,这就全靠XSLT的数据组织功能了。AJAX、XMLHttpRequest组件、XML+XSLT,这是实现本工具的三个重要技术,缺一不可。至于如何读出用户的del.icio.us书签列表,这是del.icio.us开放API中提供的服务,你只要Get这个url即能看见你的所有书签http://del.icio.us/api/posts/all,返回的是一组utf-8编码,xml组织的数据。

技术:

  1. 客户端AJAX,或站内AJAX:此AJAX的特点是执行脚本所在的浏览页面和装载脚本代码的地址必须是同一站点,或者是脚本代码本身就放在客户端本地。比如我的站点想应用AJAX技术提供给浏览用户,这个实现AJAX的脚本代码必须放在我的域名地址下或者是由客户下载代码到本地后执行,这本来就是XMLHTTP规范的东西,即xmlhttprequest不能进行跨域操作。(我的AJAX翻译小工具即出自这个原理)
  2. 服务器端代理AJAX:用户利用AJAX可以实现跨域的读取数据,其实数据不是直接由客户端发往请求服务器的,而是通过代码所在的站点进行转接请求操作,如我的那个Google排名查询工具,用户打开了我服务器上的执行页面,对Google的服务器进行数据请求,其实这其中是通过我的web所在的服务器进行转接的,客户发出命令,命令发到我的web上,web服务端脚本利用本身的xmlhttprequest(注:对于服务器,这时调用xmlhttprequest组件其实属于本地操作)对google进行数据查询,得到查询结果在返回给客户端,起到了媒人的作用。(看出不爽的地方了吗?没看出看下面的解释)
  3. 客户端代理AJAX:这个想法真的很棒,太有创意了。本篇介绍的这个工具就是利用了这一条。我在安装那段第二条中写道:打开del.icio.us随便进入一个页面,为什么要必须打开一个del.icio.us的页面呢?因为只有打开这个页面你的浏览器当前域就属于del.icio.us了,这时候点击快捷栏上的书签时调用AJAX其实就赋予了代码的del.icio.us域的权利,所以才能实现从web1取代码后和web2进行通讯(以往这就属于跨域了),关键就是先要打开一个del.icio.us的页面

利用第三个客户端代理技术最大的好处就是减轻了服务端的WebServices请求压力,我写的那个Google排名查询系统很多网友反映数据老是出错,这我也没办法,就是因为服务器压力过大再加上XMLHttpRequest组件的不稳定所致,现在通过客户端代理,压力全部放在了用户自己的机器上,出错几率当然降为最低了。其实在知道这个工具之前,我也曾想做个基于浏览器的tag浏览小工具,但是还是技术不行啊,想法也没人家大胆,经验也不足,我怎么没想到利用url实现远程跨域操作呢?不得不承认,这个工具所应用的技术和实现创意是我至今见过对AJAX驾驱最强的,尤其是利用url进行跨域操作以及通过XSLT实现超轻量级的数据库,堪称经典。相比之下,那些用AJAX只是实现无刷新读取数据的应用现在看起来是那么的粗陋。

本工具基于的这个客户端代理技术请看作者写的这篇——Creating A Client-Side Web Service Broker


服务端代理和客户端代理比较


界面截图

注:全文完

惨,上CSDN头条了,怪不得耳朵一直热热的……

惨,那篇《AJAX的七宗罪》让CSDN给放到头条了,骂声一片,怪不得耳朵一直热热的……

我这个人还是胆小啊,连回复都没敢去,凭我多年在CSDN混得经验,越参合人家越来劲,不把你骂个体不完肤誓不罢休的,还是老老实实在我的老窝里小声牢骚下就行了^_^

其实对AJAX说yes还是no都无关紧要。AJAX给大家展示的是一幅唯美技术,了解它学习它,重要的是这个过程。那片文章中提起的两个用AJAX用过头的网站,其中的一个已经放弃了,全部改成普通页面了,这说明什么?技术是无罪的,用好用坏在于人,这就像一把刀,可以杀人,也可以切菜,一个道理。

虽然我写了那篇文章,但最近我还是尝试在用它,感觉还行吧。今天给一个客户修改CMS系统,工作量小,我有心尝试下新鲜热乎的AJAX,给一个列表加入了无刷新更新数据和排序,碰到了一个难题就是POST表单时对字节的编码,网上能找到的都不好用,最后还是自己钉钉补补改了一个自认为完美的

<script language="vbscript">function urlencoding(vstrin)    dim i,strreturn,strSpecial, t    strSpecial = " <>""#%{}|^~[]`‘&?+"&chr(13)&chr(10)    strreturn = ""    for i = 1 to len(vstrin)        thischr = mid(vstrin,i,1)        if abs(asc(thischr)) < &hff then            if instr(strSpecial,thischr)>0 then                if thischr = " " then                  strreturn = strreturn & "+"                else                  t = hex(asc(thischr))                  if len(t) = 1 then t = "0"&t                  strreturn = strreturn & "%" & t                end if            else                strreturn = strreturn & thischr            end if        else            innercode = asc(thischr)            if innercode < 0 then                innercode = innercode + &h10000            end if            hight8 = (innercode  and &hff00)\ &hff            low8 = innercode and &hff            strreturn = strreturn & "%" & hex(hight8)_
& "%" & hex(low8) end if next urlencoding = strreturnend function</script>

注:全文完

再论AJAX下的WEB UI设计的七宗罪

昨天写了篇AJAX的七宗罪,有人专门给我发了mail,也有人专门写了文章指出我所说观点的弊端。今天无力也没必要再一一加以论证了,我就单独以WEB UI的眼光来看看AJAX。

AJAX有三大特点:异步交互(Asynchronous),基于JavaScript 脚本,和XML封装数据。这三点包括了AJAX运行的全部特征,从客户端用javascript开始request数据后传到server,server用xml做接口用异步方式response数据,javascript在通过parseXML后最终进行UI处理。整齐干净利落的流水线工作,看起来毫无瑕疵,但是大家都忽略了其中的一个关键就是javascript。以下我一一罗列什么样的用户在访问AJAX时会碰到问题:

  • 1、早期的浏览器,如IE4
  • 2、关闭了浏览器的javascript脚本或者IE下完全禁用ActiveX
  • 3、使用了企业级的防火墙、一些安全防护软件和IE里安全级别设置较高
  • 4、一些非主流或者冷僻的浏览器,如盲人浏览器、手机浏览器
  • 5、在IE或者FireFox里用了第三方浏览器插件或者使用了广告拦截
  • 6、搜索引擎的爬行蜘蛛,一些基于http方式的软件,如离线浏览
  • 7、一些浏览器安全软件(插件)的正常监控

列表中1、4估计情况还好点,起码部分的javascript能正常运行,这就给了UI设计者喘息之气,起码可以从页面底部显示一个本站推荐1024*768的分辨率下访问类似的提示信息或者跳转页面(跳转到无AJAX的页面——两手准备)的机会,但是像2、3、5情况,javascript根本不能运行就谈不上分析是不是支持AJAX了。我的Maxthon默认打开了软件本身的所有广告拦截设置,并且在每打开一个页面时运行一个叫做“清除烦恼”的第三方插件,这两个强强联手让我访问一些AJAX高级应用的web时普遍都出错。

还有一个我认为是很不爽的就是在AJAX下推崇的是无刷新,号称是大大提高了人机交互,在我看来恰得其反。http://www.standards-schmandards.com/exhibits/ajax/是一个纯AJAX制作的计算器的sample,输入数字后点击ADD,页面不用刷新酷酷的通过server端计算数据并传回结果。这个计算器曾经是大家相互link和学习的好例子,现在却成了基于AJAX下WEB UI的一个疑问。那就是点击ADD后用户不知道什么时候数据是更新了,也许你们也和我一样,输入6+3后然后开始等待,当value变成9的时候就知道运算结束了。晕,既然我知道结果是9那我算它干什么啊。当然,在屏幕上显示一个像"Loading"或者"正在计算中,请稍候..."这样的提示是个好主意,但是这同样需要用户去用眼睛盯着看结果的变化,而且并不知道数据的运算或者数据的传输进行到怎样一个情况,普通的submit表单起码还能看见一个进度条显示页面下载情况。还要注意的是这只是一个计算器,如果屏幕上有很多个计算器在进行同时的异步运算,不管是显示N个"Loading",还是其他的方式的提示都是不尽人意的UI设计。

我还是坚持我的观点,AJAX在目前的web下最适合的就是企业级应用,大家在开发B/S系统时经常碰到的二三级联动或者树型目录的节点加载,用AJAX来实现简直太easy和完美了。而且在企业级应用不会出现以上所说的javascript问题,开发商完全有理由毫不犹豫地要求客户:我们的系统应用了最新最酷的web技术,所以要求系统用户的浏览器必须是IE6……

注:全文完

AJAX的七宗罪

引子

2005.2.18,Jesse James Garrett 的一篇A New Approach to Web Applications引出了AJAX这个web界的新名词。加上新宠儿在降生下来就和足球名队阿贾克斯、Google Suggest  Google Maps这些大腕息息相关,不想出名都难啊。但似乎人们给与AJAX的期望有点太高了,甚至有人提出了用AJAX取代Java Applet和Flash。不知Flickr是不是也听到这种呼声才把自己的Flash UI转向了普通的Javascript。AJAX是个伟大的东西,它是在不创造新技术的前提下诞生的一个标准,凭这一点就能招来大批的狂热追随者,AJAX看起来更像是杨过和小龙女练得玉女素心剑一样,分开来没有什么破坏力,但是二者合一就威力无比。

罪之一:对搜索引擎的支持不好

这其实更像一个大大的讽刺,AJAX的鼻祖是Google,但却对Google自己支持最不好了,GMail主界面除过Top和Bottom外没有一个链接就是最形象的讽刺了。虽然Mail本身是个私人的应用系统,但这个无链接的设计界面恰恰给AJAX开了个坏头。Flash也有同样有这个毛病。没有链接的web就像森林中迷路的羔羊,这句看似广告语,其实是web设计的根本原则。

罪之二:编写复杂、容易出错

javascript本是是个轻量级的小东西,现在被强迫重用起来,负担可想而知。javascript对OOP的支持很少,这就限制了javascript代码的可重用可封装等等,从Google Mpa还是其他一些应用中能看到的都是无数的这样的文件包含,这些除了让程序员头昏的更快点,一点好处都没有。更可怕的是在javascript中竟然没有一款顺手的Debug软件,很多写js的老手到今天还是用最原始的alert("")来调试,splinetech JavaScript HTML Debugger 算是一个看起来还像个样子的调试器吧,可惜不是免费的,几十大刀让我这种穷人只能望而生叹了。

罪之三:冗余代码更多了

和上面说的差不多,层层包含js文件是AJAX的通病,再加上以往的很多服务端代码现在放到了客户端,所以每次打开一个页面会包含很多的无用的js文件也一同下载下来。虽然宽带越来越普及,但是减少代码冗余还是每个web设计者的必修课。

罪之四:破坏了Web的原有标准

什么叫破坏web标准?点击查看全部,这就是破坏了web标准。好好的A标签放着不用,偏要用span。这种例子很多,flickr中的标题单击后可以更改,这虽然(也包括我)是大家一致叫好觉得方便的设计,但同时这也是歧义了web元素本身的含义,物是人非这个词不知道用的合不合适?

罪之五:缺少一个没有标准之争、没有back和history的浏览器

哈哈,这句话语有点讽刺意义。现在的浏览器市场,不管是IE还是FireFox还是Opera等等。浏览器和浏览器之间的差异一直都是web设计者心中永远的痛,支持的css不一样,支持的客户端脚本不一样,有的竟然连客户端脚本的用法都有不同。这让程序员非常苦恼,最明显的就是调用xmlhttprequest了,req=(window.XMLHttpRequest)?new XMLHttpRequest():new ActiveXObject("Microsoft.XMLHTTP");这段创建xmlhttp对象的代码就是为了适应IE和非IE两天阵营的浏览器的经典例子。说是没有back和没有history的浏览器,这也是一个讽刺,主要是指在AJAX下点击链接是不Redirect页面,所以不存在后退和前进了,同样,没有后退和前进也就无存找浏览历史纪录了。back和history存在的根本就是url的改变,在AJAX下人们发现不改url也同样能达到内容改变这个酷酷的特点,何乐而不为呢?look http://www.dux2005.org/和http://www.zagodesign.com/,我承认这两个站确实做得非常棒,但除了酷酷的感觉外,毫无用处。

罪之六:XML只是用来打幌子

xml从诞生那天起就被一致看好,大有非xml不娶之势,我想Jesse James Garrett也是为了趋于流行才把xml强行加入ajax的吧。xml有一个致命的缺点,那就是加载的资源耗费,这好像是所有平台下xml的通病。google map虽然是Jesse James Garrett推荐的AJAX的品牌代言人,但是gmap并没有用xml,而是用了原生的javascript数组,我自己在用AJAX从服务端传回数据时也从来不用XML,因为它让我更繁琐让系统更慢。服务端首先要调用xml对要传输的数据进行封装,客户端得到数据后再调用xml进行解析,简直是画蛇添足。AJAX的一个重要特点是要身法轻盈,数据的传输尽量单一和简陋,如果确实需要传输大量复杂的数据,也应该通过多次调用传回。

罪之七:世界这么大却找不到自己的家 

AJAX适用于什么?能干什么?能带来什么?在网站上用AJAX那是笑话,除非像Google Map和Flickr这样的专业领域的网站外,普通网站根本没必要用这个技术;在庞大的企业应用市场估计还能有AJAX的一点容身之地,不过在MS、SUN不会看着AJAX这个野孩子来在他们的地盘上撒泼的,如果大家都用AJAX,那java给谁卖?.net给谁卖?所以AJAX在企业应用也不是长久之地。所以,AJAX现在找不到自己合适的位置是个很大的尴尬。疑病乱投医,最近把AJAX的矛头指向Flash和Applet就是一个例子。

当然,我也不是要把AJAX扁的一无是处,我本人就非常喜欢这门技术,它能让web设计者的眼球更加宽广,让一些大胆的设计成为现实,但是我也会很冷静的小心翼翼的利用这个利器,利器虽好,一不留神刺伤的是自己。

PS:这篇文章是昨晚写的,今早却神奇般的从网上看见了一篇文章Ajax: 99% Bad,文章是针对2000年那片著名的Flash: 99% Bad 写的,其中的观点和我所说的七宗罪中的几宗相似。

注:全文完

Ajax内部交流文档

一、使用Ajax的主要原因二、引用三、概述五、Ajax的优势六、Ajax的问题七、结束语

Ajax: A New Approach to Web Applications(中文译版)

Jesse James Garrett的那篇Ajax: A New Approach to Web Applications很多人一定看过,今天凑巧看见了中文版的。原文地址(英文):http://www.adaptivepath.com/publications/essays/archives/000385.php 译文地址:http://info96.k12studio.com/~nio/comments.php?id=242_0_1_0_C

AJAX经典文章

  • http://www.dragonson.com/doc/ajax.html
    Ajax内部交流文档
  • http://info96.k12studio.com/~nio/comments.php?id=242_0_1_0_C
    简单地对 Ajax 进行描述介绍
  • http://www.adaptivepath.com/publications/essays/archives/000385.php
    Ajax: A New Approach to Web Applications
  • http://jibbering.com/2002/4/httprequest.html
    Using the XML HTTP Request object
  • http://developer.apple.com/internet/webcontent/xmlhttpreq.html
    Dynamic HTML and XML: The XMLHttpRequest Object
  • http://del.icio.us/popular/ajax
    del.icio.us / popular / ajax
  • http://www.fiftyfoureleven.com/resources/programming/xmlhttprequest/examples
    XMLHttpRequest & Ajax Working Examples
  • http://www.xml.com/lpt/a/2005/02/09/xml-http-request.html
    Very Dynamic Web Interfaces
  • http://www.standards-schmandards.com/index.php?2005/03/01/16-ajax-and-accessibility
    AJAX and Accessibility
分页:[<<][1][2][>>]

日历

<< 2005·9 >>

Sun

Mon

Tue

Wen

Thu

Fri

Sat

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

Search

Google

网站目录

  • 透析网络 (44)
  • 杂七杂八 (39)
  • Web开发 (35)
  • 心情随笔 (33)
  • 我的Java之路 (16)
  • 编程学院 (14)
  • 音影软 (14)
  • CMS专栏 (4)
  • 网文收藏 (3)
  • 网摘短评 (3)
  • 一亩三分试验田 (3)
  • OA和电子政务 (2)

文章归档

  • 2005 September (4)
  • 2005 August (30)
  • 2005 July (13)
  • 2005 June (34)
  • 2005 May (38)
  • 2005 April (32)
  • 2005 March (37)
  • 2005 February (15)

Tags

  • 互联网 (62)
  • web开发 (48)
  • 技术文化 (38)
  • blog (35)
  • 幽默搞笑 (26)
  • 心情随笔 (22)
  • webmaster (21)
  • 转载 (18)
  • 编程之道 (17)
  • Google (17)
  • 搜索引擎 (16)
  • web设计 (15)
  • 中国 (14)
  • 生活 (13)
  • Eclipse (13)
  • 图片 (12)
  • 无聊灌水 (12)
  • javascript (12)
  • IT (12)
  • 插件 (12)
  • ajax (11)
  • rss (10)
  • 微软 (10)
  • 软件使用 (10)
  • del.icio.us (10)
  • 社会现象 (9)
  • 开源 (8)
  • 新大陆 (8)
  • 小工具 (7)
  • adsense (7)
  • tag (6)
  • java (6)
  • 软件工具 (6)
  • seo (6)
  • opensource (6)
  • 政治 (6)
  • 软件开发 (6)
  • Web2.0 (6)
  • search (5)
  • 游戏 (5)
  • 我爱老婆 (5)
  • domain (5)
  • flickr (4)
  • cms (4)
  • 翻译 (4)
  • 音乐 (4)
  • 下载 (4)
  • 学习技巧 (4)
  • 网摘短评 (3)
  • 家庭 (3)
  • 日本 (3)
  • 精品网摘 (3)
  • 破解 (3)
  • 电影 (3)
  • QQ (3)
  • WebServices (3)
  • flash (2)
  • 我的试验田 (2)
  • 浏览器 (2)
  • 台湾 (2)
  • 两岸 (2)
  • 英汉互译 (2)
  • 数据库 (2)
  • windows (2)
  • 电子政务 (2)
  • DIY (2)
  • html (2)
  • 新闻媒体 (2)
  • 新闻 (2)
  • SNS (2)
  • 虚拟主机 (2)
  • 文化 (1)
  • 硬件 (1)
  • tip (1)
  • lifehack (1)
  • 教育 (1)
  • wiki (1)
  • KMS (1)
  • struts (1)
  • 项目管理 (1)
  • 啤酒 (1)
  • 域名解析 (1)
  • css (1)
  • mp3 (1)
  • xmlhttp (1)
  • xml (1)
  • mvc (1)
  • 工作流 (1)
  • workflow (1)
  • DVD (1)
  • 刻录 (1)
  • 怪癖 (1)
  • OO (1)
  • 超级女声 (1)
  • 娱乐 (1)
  • 个人门户 (1)
  • 影评 (1)
  • 地球 (1)
  • 环境 (1)
  • 自然灾害 (1)
  • 地理 (1)
  • 卡特里娜 (1)

Powered By Z-Blog 1.4 SP1 Build 50824

Powered By Edong.com

Copyright 1999-2005 duduwolf.com Some Rights Reserved.