首 页 网络编程
网页制作 图形图象 操作系统 冲浪宝典
软件教学 认证考试

网络安全 网络办公 行业资讯 评测对比
您当前位置:站长天空 -> 认证考试
xmlhttp对象封装技术_ajax教程
作者:网友供稿 点击:0
推荐
西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!可在线rar解压,自动数据恢复设置虚拟目录等.免费赠送访问统计,企业邮局.Cn域名注册10元/年,自助建站480元起,免费试用7天,满意再付款!P4主机租用799元/月.月付免压金
站内搜索
文章页数:[1] 

    ajax技术的实现主要依赖于xmlhttprequest,但我们在调用其来进行异步数据的传输时,由于xmlhttp是个短线过程(处理事件完成后就销毁)如果不对该对象进行包装处理的话,就不得不在需要调用的地方重新构建xmlhttprequest,每次调用都要写一大段的代码,实在不是个好办法。好在现在很多开源的ajax框架都提供了对xmlhttp封装的方案。这里以ajaxtags自带的prototype-1.4.0.js为母版,来看看如何将xmlhttp对象封装成一个可复用的方法。

    在prototype.js中,首先定义了一个变量:Ajax
   var Ajax = {
      getTransport: function() {
        return Try.these(
          function() {return new ActiveXObject(Msxml2.XMLHTTP)},
          function() {return new ActiveXObject(Microsoft.XMLHTTP)},
          function() {return new XMLHttpRequest()}
      ) || false;
   },

    activeRequestCount: 0
}
变量返回了一个xmlhttprequest,可以看到,如果我们调用了Ajax.getTransport(),每次都会返回一个新的xmlhttprequest对象。
   在Ajax变量中定义了一个基础方法Ajax.Base和该基础方法的原型(初始时,每个脚本方法默认都有个空的原型,该原型会继承Object的原型,如果我们在Object中改变了原型,则所有的脚本方法都会被改变。) 该基础方法被Ajax.Request所继承,注意的是,如果在Ajax.Request中填充了继承的原型的同名方法或变量,则会实现重载。
    Ajax.Base原型中最主要的是setOptions方法,过会我们就会用到。
setOptions: function(options) {
    this.options = {
      method:       post,
      asynchronous: true,
      parameters:  
    }
   prototype中对request是通过定义Ajax.Request原型(Ajax.Request.prototype)来实现的。但我们并不能直接对Ajax.Request进行调用,主要原因是Ajax.Request并没有提供一个统一处理的过程。而且我们可能需要通过request 再取得response。(试想一下,客户那边发出一条信息,都始终没与收到回复,那是会让人觉得很恼火的事~),prototype同样为我们封装好了resoponse(Ajax.Responders),但两者都是相互独立的,如何把他们进行整合呢?

    在 prototype中给我们提供了两个方案,一个是Ajax.Updater,另一个是Ajax.PeriodicalUpdater,两个共同点都是必须传入3个参数:
container:
    response数据要传达的位置,该位置通过html标签的id进行定义,比如你要把返回的数据输出到html中的某个<div>中,则只要把container改成该id的值就可以了。如果找不到该container,则会发生脚本错误。
url:
    request请求要传递的目的地。该目的地应该是个servlet或jspservlet,因为request对象只能被servlet中的do***方法自动获取。
options:
    结构应该与上面Ajax.Base定义的setOptions()中的option结构相同,如果为空或不写,则采用 Ajax.Base定义的初始值(没有传递任何参数时使用)。
    两者的区别在与Ajax.Updater返回给container的是完整的responseText,只有在responseText完全取得又没发生异常时才会把内容写到container里面,而PeriodicalUpdater在获取responseText时,不管是否已经完整取得,就把内容填进container,直到发生异常或完全取得responseText。大多数情况应该使用第一种方法,因为第一种方法在发生异常时会把异常信息显示在container里面,而第二种就不一定了。
    既然已经把xmlhttp封装好了,我们只需要设置好前面所说的3个参数就可以了,要注意的是,设置options参数,一定要按照base中的options结构进行设置,如果我们使用post方法,还可以在opitons中设置postBody属性,把要传递的queryString 放到body中,一个使用post方法进行传递的脚本例子如下:

 

 /*表单提交用post方法*/
 function doRequest(container,paraments,url){
    var options ={
      method:       post,
      asynchronous: true,
      postBody: paraments
    };
    new Ajax.Updater(container,url,options);   
 }

最后不得不说的是中文编码问题,prototype对传递的参数都进行了编码转换工作,每个传递值通过encodeURIComponent 进行了处理.编码会被转换成utf-8,在后台获取request时,应该统一使用request.setCharacterEncoding("UTF-8")对request设置编码,而不必管页面的编码格式是什么.如果使用post方法进行传递数据,则会自动执行:
    request.setHeader(Content-type,application/x-www-form-urlencoded).确保传递数据编码格式的正确.

http://blog.csdn.net/lemonfamily/archive/2007/01/30/1498248.aspx


文章整理:站长天空 网址:http://www.z6688.com/
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

文章页数:[1] 


放大字体显示 缩小字体显示 打印文章 推荐给朋友
热门文章
·把.NET程序部署到没有安装.NET Framwork的机器上-.NET教程,.NET Framework
·在java中实现sql的select函数功能-JSP教程,Java技巧及代码
·利用排序规则特点计算汉字笔划和取得拼音首字母-数据库专栏,SQL Server
·使用脚本自动修改ip设置-.NET教程,面向对象编程
·ASP.NET2.0下含有CheckBox的GridView删除选定记录实例-.NET教程,评论及其它
·XMLHTTP---介绍-JSP教程,Java与XML
·JAVA与数据库连接方法(一)-JSP教程,数据库相关
·Lucene.net 实现全文搜索-.NET教程,Asp.Net开发
·ASP+SMTP完成邮件群发功能-ASP教程,ASP应用
·SQL无法连接-数据库专栏,SQL Server
最新文章
·photoshop照片处理:表现超酷的金色色调_photoshop教程
·google adsense广告应避免18个错误_网赚技巧
·郭凡生:行业网站没技术门槛 只懂销售_站长访谈
·想建站?应该如何定位和掌握什么技术?_站长心得
·个人网站创业 不要惧怕技术门槛_站长心得
·photoshop打造“非主流”颓废照片特效_photoshop教程
·速成不是网站的根本_站长心得
·网站推广之半年打造10万ip的流量_站长心得
·保持网站流量 对网站改版方案建议_站长心得
·google adwords广告关键词须注意的问题_google推广
相关主题
  • xmlhttp xmldoc 与 c#中dataset的结合 实现ajax简单示例_ajax教程
  • xmlhttp获取web访问头信息和网页代码_asp技巧
  • XMLHTTP获取web访问头信息和网页代码-ASP教程,ASP技巧
  • XMLHTTP开发Web 客户端-.NET教程,Web Service开发
  • XMLHTTP Get HTML页面时的中文乱码之完全客户端Script解决方案-ASP教程,ASP技巧
  • 西部数码虚拟主机

    友情链接
    CNNIC 西部数码
    万网 自助建站
    虚拟主机 asp空间
    域名注册 域名
    域名申请 主页空间
    论坛空间 网站空间
    国际域名 虚拟空间
    空间租用 DDOS防火墙
    成都主机托管 四川主机托管
    主机租用 服务器租用
    网站目录 自助建站
    虚拟主机 网址大全
    软件下载
    自助链接
    虚拟主机资讯 特价虚拟主机
    版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!
    关于我们:站长天空:专业提供最新的站长资讯、在线教程、虚拟主机权威评测、虚拟主机性能对比、网站制作教程,开发教程,站长工具。包括网页制作教程、冲浪宝典、编程参考、操作系统、软件教学、行业动态等。
    特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
    发表评论 打印  刷新     关闭