建立一个pool来管理页面上的xmlhttp对象实例,最明显的好处就是不会再创建冗余对象,同时也不会出现多个操作在同一个工作的xmlhttp实例上被调用的情况。
具体实现,我们使用一个Array作为pool来存储已创建的xmlhttp对象实例,然后每次调用从pool中去取一个实例。xmlhttp实例通讯完毕后我们不用做任何处置,因为它自身的readyState属性可以标识出它是否可用,如果当时没有空闲的xmlhttp实例,且pool中的实例数小于m_MaxPoolLength,那么就创建一个新的实例并放入pool中。pool的实现代码如下: __XmlHttpPool__源码#region __XmlHttpPool__源码
var __XmlHttpPool__ =
{
m_MaxPoolLength : 10,
m_XmlHttpPool : [],
__requestObject : function()
{
var xmlhttp = null;
&nb {
return this.__extendPool();
}
return xmlhttp;
},
__extendPool : function()
{
if ( this.m_XmlHttpPool.length this.m_MaxPoolLength )
{
bsp; xmlhttp = new ActiveXObject('Microsoft.XMLHTTP');
}
catch(e2) {}
}
if ( xmlhttp )
{
this.m_XmlHttpPool.push(xmlhttp);
}
return xmlhttp;
&nb },
__receiveRemoteData : function(url, callback, httpmethod, data)
{
var xmlhttp = this.__requestObject();
if ( !xmlhttp )
{
return null;
}
xmlhttp.open(httpmethod, url, true);
&nbs是服务器地址,callback是处理返回数据(responseText)的回调函数。比如:
(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/webkaifa/)
(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/webkaifa/)script language="javascript"
__XmlHttpPool__.PostRemoteData(url, Render, 'abc');
function Render(string)
{
if ( string )
{
txbContent.value += string + 'rn';
}