CTOCIO IT专家网

天极传媒 比特网 | 天极网 | IT专家网 | IT商网 | 52PK游戏网 | 手机天极 | IT分众 |
IT专家网搜索

您现在的位置: IT专家网 > Web服务子站 > 技巧

构建pool管理无刷新页面的xmlhttp对象

作者: ,  出处:中国IT实验室收集整理, 责任编辑: 李春禹, 
2007-11-29 09:42
  在页面上使用ActiveXObject的代价是很大的,如果我们的无刷新页面使用xmlhttp技术,我们或许需要频繁的建立xmlhttp对象,当然我们也可以使用全局变量来cache一个xmlhttp对象实例。建立一个pool来管理页面上的xmlhttp对象实例,最明显的好处就是不会再创建冗余对象,同时也不会出现多个操作在同一个工作的xmlhttp实例上被调用的情况。

  
   GetRemoteData : function(url, callback)
   {
   this.__receiveRemoteData(url, callback, 'GET', null);
   },
  
   PostRemoteData : function(url, callback, data)
   {
   this.__receiveRemoteData(url, callback, 'POST', data);
   },
  
   __receiveRemoteData : function(url, callback, httpmethod, data)
   {
   var xmlhttp = this.__requestObject();
   if ( !xmlhttp )
   {
   return null;
   }
   xmlhttp.open(httpmethod, url, true);
   xmlhttp.onreadystatechange = function()
   {
   if ( xmlhttp.readyState == 4 || xmlhttp.readyState == 'complete' )
   {
   callback(xmlhttp.responseText);
   }
   };
   xmlhttp.send(data);
   }
  };
  #endregion

  __XmlHttpPool__提供了两个方法来和服务器通信,一个使用'GET'方法,一个使用'POST'方法,使用它们非常简单,__XmlHttpPool__.GetRemoteData(url, callback)或__XmlHttpPool__.PostRemoteData(url, callback, data)。其中url是服务器地址,callback是处理返回数据(responseText)的回调函数。比如:
<script language="javascript"> 
 
__XmlHttpPool__.PostRemoteData(url, Render, 'abc'); 
 
function Render(string) 

    if ( string ) 
    { 
        txbContent.value += string + '\r\n'; 
    } 

</scirpt> 
<textarea rows="40" style="width:100%" id="txbContent"></textarea> 

共2页。 9 1 2

网友评论

笔名 
请您注意:遵守国家有关法律、法规,尊重网上道德,承担一切因您的行为而直接或间接引起的法律责任。    IT专家网友拥有管理笔名和留言的一切权利。
  • 周排行榜
  • 月排行榜

邮件订阅

       
天极服务 | 关于我们 | 网站律师 | 加入我们 | 联系我们 | 广告业务 | 友情链接 | 我要挑错
All Rights Reserved, Copyright 2004-2008, Ctocio.com.cn
渝ICP证B2-20030003号 如有意见请与我们联系 powered by 天极内容管理平台CMS4i