最近互联网上比较火热的话题当然是关于web2.0的应用,其中ajax又是web2.0的核心之一。
ajax的工作原理相当于在用户与服务器之间加了—个中间层,使用户操作与服务器响应异步化。这样把以前的一些服务器负担的工作转嫁到客户端,利于客户端闲置的处理能力来处理,减轻服务器与带宽的负担,从而达到节约isp的空间及带宽租用成本的目的。 【相关文章:第三层交换机技术白皮书】
ajax是asynchronous javascript and xml 的缩写。它并不是一门新的语言或技术,它实际上是几项技术按一定的方式组合在一在同共的协作中发挥各自的作用,它包括:使用xhtml与css标准化呈现;使用dom实现动态显示与交互;使用xml与xslt进行数据交换与处理;使用xmlhttprequest进行异步数据读取;最后用javascript绑定与处理所有数据。 【扩展阅读:Ajax,未来的WebServices?】
首先,我们需要用javascript来创建xmlhttprequest 类向服务器发送一个http请求, xmlhttprequest 类首先由internet explorer以activex对象引入,被称为xmlhttp。 后来mozilla﹑netscape﹑safari 与其他浏览器也提供了xmlhttprequest类,不过它们创建xmlhttprequest类的方法不同。 【扩展信息:三层交换技术解析】
我们以两个验证通行证帐号是否存在的例子来讲述ajax在实际中的应用:用文本字符串的方式返回服务器的响应来验证网易通行证帐号是否存在;以xmldocument对象方式返回响应来验证金山通行证帐号是否存在。
对于internet explorer浏览器,创建xmlhttprequest 方法如下:
xmlhttp_request = new activexobject("msxml2.xmlhttp.3.0");
//3.0或4.0, 5.0
xmlhttp_request = new activexobject("msxml2.xmlhttp"); xmlhttp_request = new activexobject("microsoft.xmlhttp");由于在不同internet explorer浏览器中xmlhttp版本可能不一致,为了更好的兼容不同版本的internet explorer浏览器,因此我们需要根据不同版本的internet explorer浏览器来创建xmlhttprequest类,上面代码就是根据不同的internet explorer浏览器创建xmlhttprequest类的方法。
对于mozilla﹑netscape﹑safari等浏览器,创建xmlhttprequest 方法如下:xmlhttp_request = new xmlhttprequest();
如果服务器的响应没有xml mime-type header,某些mozilla浏览器可能无法正常工作。 为了解决这个问题,如果服务器响应的header不是text/xml,可以调用其它方法修改该header。
xmlhttp_request = new xmlhttprequest();
xmlhttp_request.overridemimetype(text/xml);在实际应用中,为了兼容多种不同版本的浏览器,一般将创建xmlhttprequest类的方法写成如下形式:
try
{ ... 下一页