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

2016-02-19 16:59 7 1 收藏

岁数大了,QQ也不闪了,微信也不响了,电话也不来了,但是图老师依旧坚持为大家推荐最精彩的内容,下面为大家精心准备的Ajax并不神秘揭下各种Ajax控件和类库的小裤衩,希望大家看完后能赶快学习起来。

【 tulaoshi.com - Web开发 】

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

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

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/webkaifa/)

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

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/webkaifa/)

  观点二: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}

  一口气说这么多,希望对大家有点用处^_^

附推荐一个开源的Ajax Blog系统(中英文版):
http://www.sourceforge.net/projects/x2blog/

来源:http://www.tulaoshi.com/n/20160219/1613812.html

延伸阅读
标签: Web开发
网页制作Webjx文章简介:您可能已经准备开始编写第一个Ajax应用程序了,至少也希望认真读一下参考资料中的那些文章了吧?但可以首先从这些应用程序如何工作的基本概念开始,对XMLHttpRequest对象有基本的了解。在下一期文章中,您将掌握这个对象,学会如何处理JavaScript和服务器的通信 以DOM结束 最后还有DOM,即文档对象模...
标签: Web开发
处理响应 现在要面对服务器的响应了。现在只要知道两点: 什么也不要做,直到xmlHttp.readyState属性的值等于4。 服务器将把响应填充到xmlHttp.responseText属性中。 其中的第一点,即就绪状态,将在下一篇文章中详细讨论,您将进一步了解HTTP请求的阶段,可能比您设想的还多。现在只要检查一个特定的值(4...
标签: Web开发
结合起来 关键是要支持所有浏览器。谁愿意编写一个只能用于InternetExplorer或者非Microsoft浏览器的应用程序呢?或者更糟,要编写一个应用程序两次?当然不!因此代码要同时支持InternetExplorer和非Microsoft浏览器。清单4显示了这样的代码。 清单4.以支持多种浏览器的方式创建XMLHttpRequest对象 /*CreateanewXML...
标签: Web开发
本文让你简单认识AJAX,了解AJAX优点、缺点以及如何运用. AJAX浅谈 AJAX技术在1998年前后开始应用于Web,之后经由Google把它发扬光大,让更多人了解到JavaScript原来可以这样使用,而不再是过去广告字显示或画面渐层等刻版印象。如今AJAX已不再是新名词或新技术,而最经典、有名的代表作算是GoogleSuggest及GoogleMaps。 ...
标签: Web开发
1. FancyUpload (演示地址) FancyUpload是一个采用Flash与Ajax(MooTools)技术实现包含上传进度条的多文件上传组件,类似于SWFUpload。 2. SwfUploadPanel (演示地址) SwfUploadPanel是一个结合SwfUpload v2.0.2与ExtJS 2.0.x开发的多文件上传面板(panel)。 3. Yahoo! UI Library: Uploader (演示地址) YUI Uploader Control结合Flash开...

经验教程

260

收藏

79
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部