Ajax 并不神秘:揭下各种 Ajax 控件和类库的小裤衩

翻译|其它|编辑:郝浩|2007-08-09 09:08:34.000|阅读 569 次

概述:

# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>

 

   Ajax  控件和类库现在真的太多了,不知不觉中增加了 Ajax  的神秘性和复杂性,看到版内很多人为此费解和伤神,决定发此贴谈谈本人对 Ajax 的观点,希望能让大家对Ajax有一个本质的认识。

观点一:Ajax 和服务器端技术毫不相关

   严格的说,与传统 web 开发相比,Ajax 是完完全全的客户端技术。由于很多控件封装了客户端和服务器端的通信过程,因此很多问题也因通信而起。事实上,不论何种 Ajax 技术,服务器端都是返回的一个纯文本流,再由客户端来处理这个文本。这段文本可以是 xml 格式,也可以是一个 Html 片段,也可以是一段 JavaScript 脚本,或者仅是一个字符串。服务器端仅仅是作为一个数据接口,客户端使用XMLHttpRequest对象来请求这个页面,服务器端在页面内写入结果文本,这个过程和普通的 web 开发没有任何区别。所不同的只是,客户端在异步获取结果后,不是直接显示在页面,而是由客户端的 Javascript 脚本处理后再显示在页面。至于各种控件所谓的能返回 DataSet 对象,Date 对象,或者其他的数据类型,都是封装了这个处理过程的结果。

观点二:DOM 模型是 Ajax 最本质的技术

   之所以没有把 XMLHttpRequest 列为最本质的技术,因为本人觉得它实在是太简单了,它只是可以让浏览器在后台请求一个页面,并将其内容交给 JavaScript 处理。真正的核心应该是:DOM 模型,即文档对象模型。在 DOM 模型里,Html 标记都被认为是一个对象,例如:div 对象,table 对象等等。DOM 模型就规定了这些对象所具有的属性、方法和事件。通过这些性质,可以对一个已经显示于浏览器的页面进行内容的修改,例如增加节点、修改节点位置,删除节点等等。而不仅仅是一个 innerHTML 属性这么简单,虽然这是一个很有用的属性。

观点三:在使用 Ajax 控件前理解它们的实现

   使用 Ajax 控件的确可以提高效率,但如果你空中楼阁般使用控件,那就得不偿失了。从一个控件换到另外一个控件又会有一个漫长的学习曲线。所以应该从底层了解其,况且 Ajax 实在不是什么高深的技术。其实任何东西的最底层其实都是简单的,但如果封装了这些底层的东西,事情会变得复杂和难以理解。以Asp.net 为例,它的定制特性可以使得只要在方法前加上[ajax method]类似这样的标志就可以称为一个异步方法,相信这使得 Asp.net Ajax 开发显得更加高效或者是神秘,而更多的事情则被封装了。同样记住一条,任何对服务器端的请求仅仅是返回纯文本,我们不一定要依赖于封装好的处理过程,而完全可以自己来实现。

观点四:学好 JavaScript

   在大多数人看来,JavaScript 总不是那么一种正规的语言,随便 copy 一段就碰巧能运行,学过c之类的人,一看也能看懂,而且在浏览器中常常有脚本错误提示,所以潜意识觉得总不能付之以大任。事实上,要学好 Ajax,这就完全是一种错误的看法。Javascript 作为一种脚本语言,其语法的确不是很严格,但并不妨碍其完成诸多复杂的任务,没有 JavaScript,就没有Ajax。所以本人强烈建议,学 Ajax 前,一定要好好研究一番 JavaScript,一般来讲,如果能顺利看懂 prototype 框架的代码(如:prototype-1.3.1.js),你的 JavaScript 水平就基本过关了。同时对 DOM 模型也可以算有一个基本的了解。

观点五:Ajax 点缀:CSS

   用 JavaScript  控制 CSS 其实很简单,基本上每个 DOM 对象都有一个 style 对象,只要把 css 属性里的"-"去掉,并让随后的字母变为大写就可以作为属性使用了,例如:element.style.backgroundColor="#f00"; css 是:选择符 {background-color:#f00}

 

 


标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com


为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP