`
ham
  • 浏览: 81527 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

涅磐成凰--读Ajax缺陷有感

阅读更多
我只是个小小的程序员,对于Ajax不敢作什么长篇大论.也就讲讲自己的感触吧.

转眼一看,Ajax已经推出了两年多了.

数年前,Ajax刚出世时.曾经有很多人提出了对Ajax的质疑.声讨声一片...

今天,无聊时到Google上再次搜索那些质疑的声音.便看到了这篇于于两年前发表的小文.里面所讨论的Ajax缺陷,现在再看,会感觉有点可笑.

两年过去,那些缺陷已经不再是缺陷.现在的Ajax已经完全可以独挡一面的成熟技术.Ext,Prototype,Jquery...都为Ajax的强大提供了强有力的证明.当年那些质疑的声音也几乎听不到了.

每一样技术的成长也就是如此.历经磨难,涅磐成凰.一步一步走向了成熟.

(by ham)
----------------------------------------------------------------------
以下是搜索到的原文部分内容,供大家一起回味一下吧(原文地址:http://www.haohtml.com/site/taste/2006/07/25/680.html):

为Ajax而Ajax(Using Ajax for the sake of Ajax.)
很同意这点,当一个技术本身的生存意义由于它自身的亮点而被抹杀,不知道是这个技术的幸运还是不幸。

干掉了back按钮(Breaking the back button)
back按钮是一个标准的web站点UI的重要功能。然后,后退按钮没法和js很好的合作……
gmail似乎作的很好?不过没去仔细看过gmail如何实现后退和js相容的,被这个mistake一提醒,也许这也是ue的一个切口哦。

点击的时候没有提供一个可视化的提示(Not giving immediate visual cues for clicking widgets)
……也许是我没看懂,觉得写这段的人自相矛盾。。他说没提供可视化提示,不过是拿gmail右上角的红色提示作为例子。

阻挡了离线用户于门外(Leaving offline people behind)
看标题就清楚了,不过我持保留意见,web application和离线浏览本身似乎就存在着矛盾,要整合,可能要动很多脑子

别让我等(Don’t make me wait)
不过,ajax本身就存在着如果客户端的带宽不够,它的展示就会一塌糊涂的问题,这是它的先天缺陷,也是它崛起的先天因素--由于网速和带宽的不断增大,使得服务端与客户端的频繁通信成为可能。

假设ajax发展是一个单平台的发展。(Assuming AJAX development is single platform development)
作者文中的观点是ajax由于必须兼容多个浏览器,而没法做到只需要编码到标准的js就行,还要考虑到各个浏览器的问题……这个是js的问题,和ajax关系不大吧?

忘掉了可能多人在同时使用同一个应用(Forgetting that multiple people might be using the same application at the same time)
嗯,这其实是一个同步的问题,在b/s系统中这是一个麻烦的问题……当然,也许并不麻烦,做一个标记位就解决了吧?

太多代码让浏览器慢下来(Too much code makes the browser slow)
呃……同意这点,虽然在代码优化之后会有很大改善,但js本身运行速度慢这个缺陷还是会成为一个瓶颈。

不计划要那些禁用或者没有js的用户(Not having a plan for those who do not enable or have JavaScript)
呃……我在页面上用ajax的时候就准备放弃这些用户了,我没google那么闲,作两套系统,一套用ajax,一套纯页面。不过养成一个良好的编码习惯还是有必要,比如在超链接中不要直接设置href="javascript:..."而使用onmouseup或者onclick来触发事件,偶尔也为别人考虑考虑嘛,而且我也不能保证我的js程序在所有的浏览器上通吃。

不期然的页面闪烁和改变(Blinking and changing parts of the page unexpectedly)
我没经历过以前网页中blink标签的骚扰,所以我对作者的反感有点摸不着头脑,我觉得在适当的提示之后刷新某块页面总比整个页面的刷新看起来舒服。

没法把超链接发给朋友以及收藏(Not using links I can pass to friends or bookmark)
嘿嘿,这就是我上面提及的那点,如果编码习惯够好--而且时间够多,在超链接中为非js用户和js用户提供两套方案是可行的。

同步导致的批量操作(Asynchronously performing batch operations)
作者的意思是说ajax一次性把原来要分几次作的操作一次做掉,而导致他没法跟踪每个元素变化,没法回溯,呃……也许是有这种需求吧。。不过似乎也是可以解决的吧?

导致页面滚动并让我迷失位置(Scrolling the page and making me lose my place)
作者认为插入文本到一个页面中会导致页面发生滚动,并让其迷失方向,我没看过这么恶心的效果,没法评价,不过我对于一些ajax的导航作的不好表示不满意,我经常会迷失于一些ajax程序中而不知道我刚才上一步到了哪里……

发明了新的UI习惯(Inventing new UI conventions)
呵呵,作者用了一句话来描述这个缺点:“点击一个不明显的东东来产生一个不明显的结果”。这个归纳倒是满准确的,在很多ajax程序中,用户完全是作为一个瞎子,在抖抖索索的摸着这个ajax程序大象,在到处瞎点一气并瞎拖一气之后才掌握这个程序的用法。但是换个角度来说,最开始的web页面不也是一样?没有开始的困难接触,不会有之后的进步,只要有足够的帮助,上手任何东西都应该不会太难--除非这东西本来就不想让人觉得好用,那就是其它的问题了。

阻止了爬虫(Blocking Spidering)
同意这点,我在犹豫着使用ajax的时候,就在考虑爬虫对js的不感冒,以及爬虫该如何理解我那些以奇怪方式加载的页面,去解析ajax库似乎是一个不可能的事情,爬虫又不是人脑,如果爬虫可以媲美人脑,那就是《骇客帝国4》了。

字符集(Character Sets)
ajax本身对字符集的支持比较缺失,这个这个……设置成utf-8吧,不过作者最后也是这么说的。

使用超链接改变状态(Changing state with links (GET requests))
作者认为主流的ajax应用程序都是用get方式来工作,而这违反了W3对GET和POST方法的使用建议……我少见多怪,主流的ajax应用程序我没怎么去看,不知道是不是真的都用get,虽然ajax编码用get简单,但不表示ajax不能用post吧?

没有连带改变页面中其它相关部分(Not cascading local changes to other parts of the page)
因为ajax让人很容易控制页面中的特定部分,所以也容易导致过于关注某个点而失去对整体布局的关注。嗯嗯……这是编码的问题,表怪到ajax头上。

投资回报(Return on Investment)
作者认为ajax能够提升应用程序的可用性,但是富客户端程序并不会比纯html版本好多少……忽略这个观点,来人,把作者拖出去,账责五十
4
2
分享到:
评论
2 楼 careprad 2008-06-27  
ajax可以用用,但不能用大了.否则有你好看的
1 楼 magicgod 2008-06-06  
实际上ajax更促使了离线应用,比如有不少gears类的桌面应用直接嵌入js来开发。

ajax还是更适用于管理型的后台程序,对于前台来说作为点缀是不错的,如果纯ajax则会耗费更多的成本。

相关推荐

    20210805-太平洋证券-欧菲光-002456-涅磐重生,砥砺前行.zip

    【标题】"20210805-太平洋证券-欧菲光-002456-涅磐重生,砥砺前行.zip"所指的是一个由太平洋证券发布的关于欧菲光公司(股票代码:002456)的研究报告,这份报告的发布日期为2021年8月5日,主题是欧菲光经历困境后的...

    20210805-太平洋证券-欧菲光-002456-涅磐重生,砥砺前行.pdf

    欧菲光作为光学光电行业的龙头企业,自2012年转型后,凭借超群的技术实力和管理能力迅速成为行业龙头,并取得了显著的成绩。公司的主营产品从红外滤光片和触摸屏转向摄像头模组,全球市占率约为10%,在中国排名首位...

    3DMAX基础建模教程:POLY建模---涅磐塔[整理].pdf

    本篇教程《3DMAX基础建模教程:POLY建模---涅磐塔[整理]》便是为初学者和中级用户提供了一个学习和掌握POLY建模技术的平台,下面我们就按照教程内容的顺序,逐一详细探讨POLY建模在3DMAX中的应用。 ### 一、曲线...

    涅磐表「Nirvana Tab」-crx插件

    您将在每个新选项卡中打开Nirvana HD图像! 惊人的! 每个新标签中的真棒高品质Nirvana图片。 对于真正的粉丝,就像我一样:)您会非常有启发性的,并且您会喜欢这个不错的扩展。 简单易用(只需向下滚动即可查看更酷...

    黑客文化之莲花涅磐_全球监控与泛互联网时代的新安全人才观.pdf

    黑客文化之莲花涅磐:全球监控与泛互联网时代的新安全人才观

    环保行业2020年投资策略:外联强援内修功,行业涅磐在即.pdf

    环保行业2020年投资策略:外联强援内修功,行业涅磐在即.pdf

    基于51的4✖4矩震级埃涅磐

    【基于51的4✖4矩阵键盘埃涅磐】是一个51单片机课程设计项目,旨在通过编程和硬件设计实现一个4×4矩阵键盘的接口,并在两个数码管上显示按下键的行列位置。51单片机是广泛应用的微控制器,常用于嵌入式系统开发,...

    离散数学导论(第三版)+徐涅磐

    还不错,对同学得帮主会很大的,尤其是那些需要教材的同学

    涅磐项目大纲「Nirvana Projects Outline」-crx插件

    添加对话框以通过拖放来编辑项目层次结构(使用名称前缀)。 警告:这是正在进行的高度实验性工作。 但这有效并且应该是安全的。 它曾经修改过的数据只有项目名称。 这是我为我自己做的扩展,它允许使用其他弹出...

    九州风神黑虎鲸CPU散热器 冰翼6,涅磐重生.pdf

    随着计算机技术的飞速发展,处理器性能不断提升的同时,发热量也随之增大,因此高效的CPU散热器成为了确保系统稳定运行的关键组件之一。九州风神作为散热器领域的知名品牌,推出了其旗舰级产品——黑虎鲸CPU散热器,...

    酒类经销商的涅磐之路

    《酒类经销商的涅磐之路》是一份专为超市管理学和相关从业人员设计的参考资料,旨在探讨在现代商业环境中,酒类经销商如何适应变化、提升竞争力并实现业务的转型升级。这份文档深入剖析了酒类经销商面临的挑战,以及...

    《微力无边》读书笔记ppt模板.rar

    及至中年,涅磐而重生。颌下蓄髭,仙风道骨,好读书,喜抽烟,乐饮酒,善营销。微博出,创华艺,声名鹊起。其人可敬,其命可叹,或乃煞星投胎,虽命运多舛,其名必流于世,其身必流于波涛之中。太史公曰:牛逼。

    基于java的贪吃蛇项目

    贪食蛇游戏操作简单,可玩性比较高。这个游戏难度最大的不是蛇长得很长的时候,而是...- 涅磐模式 没有可怕的危险,你可以轻松应对 2、解开蛇自己的环境。 3、其他级别组的经典模式。 4、70个独特的里程碑赚边玩。[1]

    WP7交互特性浅析及APP设计探究

    #### 涅磐重生的WP7(以及它的历史简介) ##### WP7的起源与转型 **Windows Phone 7 (WP7)** 是微软在移动操作系统领域的一次大胆尝试,标志着从Windows Mobile时代到Windows Phone时代的过渡。与Windows Mobile...

    炫丽的JQuery树源码

    5. **AJAX交互**:在大型树结构中,为了提高页面性能,通常会采用异步加载(AJAX)技术来按需加载子节点。`$.ajax()`函数可以用来向服务器请求数据,并在接收到响应后动态插入到树结构中。 6. **插件开发**:jQuery...

    欧赔核心思维全册.doc

    例如,思维涅磐可以分为三个区间:前言、导言和思维涅磐。欧赔精算可以分为两个区间:赔率精算和欧赔最优解。 在欧赔思维的前言部分,介绍了欧赔思维的基本概念和原则,包括欧赔思维的定义、特点和应用范围等。导言...

    最准确指标期货指标公式文华财经指标真正好用指标股指期货恒指.doc

    此外,通过绘制不同颜色的线(如涅磐、宝瓶、般若等)和图标(如DRAWICON),帮助识别买入和卖出信号。 6. **交易决策**:如“持股”和“持币”标记,基于SAR指标判断是否持有股票。当SAR高于当前价格时,建议持币...

    ecs_open-api

    ### 云服务器ECS Open API知识点详解 #### 一、基本概念 **1.1 ECS (Elastic Compute Service)** - **定义**: 阿里云提供的弹性计算服务,允许用户快速搭建自己的云端服务器环境。 - **功能**: 用户可以通过ECS...

    高一语文期末试卷58[精选].doc

    - 本题考察了汉字书写规范,如“涅磐”应为“涅槃”,“膺品”应为“赝品”,“神智不清”应为“神志不清”,“勿庸置疑”应为“毋庸置疑”,强调了对常见错别字的辨别和纠正。 3. 词语解释: - 此部分考察了对...

Global site tag (gtag.js) - Google Analytics