构建一个pool来管理无刷新页面的xmlhttp对象
来源:互联网 发布:排八字软件下载 编辑:程序博客网 时间:2024/05/16 19:01
在页面上使用ActiveXObject的代价是很大的,如果我们的无刷新页面使用xmlhttp技术,我们或许需要频繁的建立xmlhttp对象,当然我们也可以使用全局变量来cache一个xmlhttp对象实例。但是这样的方法适合于同步方式xmlhttp通信,而对于异步方式xmlhttp通信将会出现问题。由于没有了进程的堵塞,用户可能再次调用同一个xmlhttp实例,如果这时前一个通信未完成,那么就失败了。
建立一个pool来管理页面上的xmlhttp对象实例,最明显的好处就是不会再创建冗余对象,同时也不会出现多个操作在同一个工作的xmlhttp实例上被调用的情况。
具体实现,我们使用一个Array作为pool来存储已创建的xmlhttp对象实例,然后每次调用从pool中去取一个实例。xmlhttp实例通讯完毕后我们不用做任何处置,因为它自身的readyState属性可以标识出它是否可用,如果当时没有空闲的xmlhttp实例,且pool中的实例数小于m_MaxPoolLength,那么就创建一个新的实例并放入pool中。pool的实现代码如下:
我已经加了birdshome@hotmail.com这个MSN,不知道是不是你的。
我把你贴出来的文档整理了,但是还是运行不起来,页面上什么都没有显示,正在郁闷中。
你的那个rar还挺唬人的,呵呵,我已经知道那是什么了。
// 我的msn不是这个,是:zhilee[at]msn.com。
建立一个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;
var pool = this.m_XmlHttpPool;
for ( var i=0 ; i < pool.length ; ++i )
{
if ( pool[i].readyState == 4 || pool[i].readyState == 0 )
{
xmlhttp = pool[i];
break;
}
}
if ( xmlhttp == null )
{
return this.__extendPool();
}
return xmlhttp;
},
__extendPool : function()
{
if ( this.m_XmlHttpPool.length < this.m_MaxPoolLength )
{
var xmlhttp = null;
try
{
xmlhttp = new ActiveXObject('MSXML2.XMLHTTP');
}
catch(e)
{
try
{
xmlhttp = new ActiveXObject('Microsoft.XMLHTTP');
}
catch(e2) {}
}
if ( xmlhttp )
{
this.m_XmlHttpPool.push(xmlhttp);
}
return 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
var __XmlHttpPool__ =
{
m_MaxPoolLength : 10,
m_XmlHttpPool : [],
__requestObject : function()
{
var xmlhttp = null;
var pool = this.m_XmlHttpPool;
for ( var i=0 ; i < pool.length ; ++i )
{
if ( pool[i].readyState == 4 || pool[i].readyState == 0 )
{
xmlhttp = pool[i];
break;
}
}
if ( xmlhttp == null )
{
return this.__extendPool();
}
return xmlhttp;
},
__extendPool : function()
{
if ( this.m_XmlHttpPool.length < this.m_MaxPoolLength )
{
var xmlhttp = null;
try
{
xmlhttp = new ActiveXObject('MSXML2.XMLHTTP');
}
catch(e)
{
try
{
xmlhttp = new ActiveXObject('Microsoft.XMLHTTP');
}
catch(e2) {}
}
if ( xmlhttp )
{
this.m_XmlHttpPool.push(xmlhttp);
}
return 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">
<textarea rows="40" style="width:100%" id="txbContent"></textarea>
__XmlHttpPool__.PostRemoteData(url, Render, 'abc');
function Render(string)
{
if ( string )
{
txbContent.value += string + '/r/n';
}
}
</scirpt> function Render(string)
{
if ( string )
{
txbContent.value += string + '/r/n';
}
}
<textarea rows="40" style="width:100%" id="txbContent"></textarea>
posted on 2004-12-27 21:38 birdshome 阅读(2021) 评论(8) 编辑 收藏 收藏至365Key 所属分类: JScript&DHTML开发
2004-12-28 09:35 | guoadou
# re: 构建一个pool来管理无刷新页面的xmlhttp对象
如果__XmlHttpPool__被用在弹出窗口中,在关闭窗口时为了避免出错,应该停止掉所有在运行的实例,所以给pool增加了一个CancelAll的方法:
CancelAll : function()
{
var extendPool = this.__extendPool;
this.__extendPool = function()
{
return null;
}
for ( var i=0 ; i < this.m_XmlHttpPool.length ; ++i )
{
this.m_XmlHttpPool[i].abort();
}
this.__extendPool = extendPool;
}
{
var extendPool = this.__extendPool;
this.__extendPool = function()
{
return null;
}
for ( var i=0 ; i < this.m_XmlHttpPool.length ; ++i )
{
this.m_XmlHttpPool[i].abort();
}
this.__extendPool = extendPool;
}
2005-01-17 14:11 | birdshome
# re: 构建一个pool来管理无刷新页面的xmlhttp对象
好,经典。收藏2005-01-20 11:54 | daniel
# 那个GetRemoteDataEx(url)在哪里?
没有看到啊,这个函数的定义在哪里?2005-04-01 09:50 | wearebug
# re: 构建一个pool来管理无刷新页面的xmlhttp对象
忘了更新这个文档了
GetRemoteDataEx : function(url)
{
return this.__receiveRemoteDataEx(url, 'GET', null);
},
PostRemoteDataEx : function(url, data)
{
return this.__receiveRemoteDataEx(url, 'POST', data);
},
__receiveRemoteDataEx : function(url, httpmethod, data)
{
var xmlhttp = this.__requestObject();
if ( !xmlhttp )
{
return null;
}
if ( httpmethod == 'POST' )
{
xmlhttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded")
}
xmlhttp.open(httpmethod, url, false);
try
{
xmlhttp.send(data);
}
catch(e)
{
__Debug__(e, data);
{
return this.__receiveRemoteDataEx(url, 'GET', null);
},
PostRemoteDataEx : function(url, data)
{
return this.__receiveRemoteDataEx(url, 'POST', data);
},
__receiveRemoteDataEx : function(url, httpmethod, data)
{
var xmlhttp = this.__requestObject();
if ( !xmlhttp )
{
return null;
}
if ( httpmethod == 'POST' )
{
xmlhttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded")
}
xmlhttp.open(httpmethod, url, false);
try
{
xmlhttp.send(data);
}
catch(e)
{
__Debug__(e, data);
}
if ( xmlhttp.status == 200 )
{
return xmlhttp.responseText;
}
return '';
},
if ( xmlhttp.status == 200 )
{
return xmlhttp.responseText;
}
return '';
},
2005-04-01 10:12 | birdshome
# 帅哥,你的回复够快的
我正在看你的代码,很多js的用法我以前没有接触过,写的真不错。我已经加了birdshome@hotmail.com这个MSN,不知道是不是你的。
我把你贴出来的文档整理了,但是还是运行不起来,页面上什么都没有显示,正在郁闷中。
你的那个rar还挺唬人的,呵呵,我已经知道那是什么了。
2005-04-01 10:38 | wearebug
# re: 构建一个pool来管理无刷新页面的xmlhttp对象
TreeView的代码还没有写完,所以我没有提供一个好的版本,现在给出的也只是为了演示效果。// 我的msn不是这个,是:zhilee[at]msn.com。
2005-04-01 10:47 | birdshome
# re: 构建一个pool来管理无刷新页面的xmlhttp对象
非常好。thanks2005-09-08 01:20 | 木野狐
- 构建一个pool来管理无刷新页面的xmlhttp对象
- 构建一个pool来管理无刷新页面的xmlhttp对象
- 构建一个pool来管理无刷新页面的xmlhttp对象
- 构建一个pool来管理无刷新页面的xmlhttp对象
- 构建一个pool来管理无刷新页面的xmlhttp对象
- 构建pool管理无刷新页面的xmlhttp对象
- XMLHTTP无刷新页面
- xmlhttp页面无刷新实现
- 一个无刷新效果定时自动更新页面的例子(ASP.NET2.0-应用xmlhttp)
- 一个无刷新效果定时自动更新页面的例子(ASP.NET2.0-应用xmlhttp)
- 一个无刷新效果定时自动更新页面的例子(ASP.NET2.0-应用xmlhttp)
- 一个无刷新效果定时自动更新页面的例子(ASP.NET2.0-应用xmlhttp)
- 怎样构建一个可刷新的无刷新应用 选项
- 利用MSXML2.XMLHTTP的无刷新技术
- 一个无刷新效果定时自动更新页面的例子
- XMLHTTP无刷新添加数据
- xmlhttp无刷新数据更新
- 用一个自动刷新的页面来刷新另外一个页面
- Java 3D
- 软件高手是这样练成的
- 愚公移山
- 电影配乐作曲家-John Powell
- 用CVSNT与WINCVS实现CVS的架设[1]
- 构建一个pool来管理无刷新页面的xmlhttp对象
- 说唱脸谱
- 电影配乐作曲家-James Honer
- 我的第一个文章
- 电影配乐作曲家-Basil Poledouris
- 使用Popup窗口创建无限级Web页菜单(1)
- 使用Popup窗口创建无限级Web页菜单(2)
- Linux,文化、市场及其他
- Squid+MRTG实现完善的缓存代理和http服务加速代理
评论
# re: 构建一个pool来管理无刷新页面的xmlhttp对象
嗯 正好用上 收藏 Thx# re: 构建一个pool来管理无刷新页面的xmlhttp对象
{
var extendPool = this.__extendPool;
this.__extendPool = function()
{
return null;
}
for ( var i=0 ; i < this.m_XmlHttpPool.length ; ++i )
{
this.m_XmlHttpPool[i].abort();
}
this.__extendPool = extendPool;
}
# re: 构建一个pool来管理无刷新页面的xmlhttp对象
好,经典。收藏# 那个GetRemoteDataEx(url)在哪里?
没有看到啊,这个函数的定义在哪里?# re: 构建一个pool来管理无刷新页面的xmlhttp对象
{
return this.__receiveRemoteDataEx(url, 'GET', null);
},
PostRemoteDataEx : function(url, data)
{
return this.__receiveRemoteDataEx(url, 'POST', data);
},
__receiveRemoteDataEx : function(url, httpmethod, data)
{
var xmlhttp = this.__requestObject();
if ( !xmlhttp )
{
return null;
}
if ( httpmethod == 'POST' )
{
xmlhttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded")
}
xmlhttp.open(httpmethod, url, false);
try
{
xmlhttp.send(data);
}
catch(e)
{
__Debug__(e, data);
if ( xmlhttp.status == 200 )
{
return xmlhttp.responseText;
}
return '';
},
# 帅哥,你的回复够快的
我正在看你的代码,很多js的用法我以前没有接触过,写的真不错。我已经加了birdshome@hotmail.com这个MSN,不知道是不是你的。
我把你贴出来的文档整理了,但是还是运行不起来,页面上什么都没有显示,正在郁闷中。
你的那个rar还挺唬人的,呵呵,我已经知道那是什么了。
# re: 构建一个pool来管理无刷新页面的xmlhttp对象
TreeView的代码还没有写完,所以我没有提供一个好的版本,现在给出的也只是为了演示效果。// 我的msn不是这个,是:zhilee[at]msn.com。
# re: 构建一个pool来管理无刷新页面的xmlhttp对象
非常好。thanks