鸟食轩

 Microsoft .NET[C#] MVP 2003
随笔 - 429, 文章 - 235, 评论 - 5529, 引用 - 356
数据加载中……

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

    在页面上使用ActiveXObject的代价是很大的,如果我们的无刷新页面使用xmlhttp技术,我们或许需要频繁的建立xmlhttp对象,当然我们也可以使用全局变量来cache一个xmlhttp对象实例。但是这样的方法适合于同步方式xmlhttp通信,而对于异步方式xmlhttp通信将会出现问题。由于没有了进程的堵塞,用户可能再次调用同一个xmlhttp实例,如果这时前一个通信未完成,那么就失败了。

    建立一个pool来管理页面上的xmlhttp对象实例,最明显的好处就是不会再创建冗余对象,同时也不会出现多个操作在同一个工作的xmlhttp实例上被调用的情况。

    具体实现,我们使用一个Array作为pool来存储已创建的xmlhttp对象实例,然后每次调用从pool中去取一个实例。xmlhttp实例通讯完毕后我们不用做任何处置,因为它自身的readyState属性可以标识出它是否可用,如果当时没有空闲的xmlhttp实例,且pool中的实例数小于m_MaxPoolLength,那么就创建一个新的实例并放入pool中。pool的实现代码如下:

__XmlHttpPool__源码


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

<scriplanguage="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>

posted on 2004-12-27 21:38 birdshome 阅读(4643) 评论(11)  编辑 收藏 网摘 所属分类: Jscript&Dhtml开发

评论

#1楼   回复  引用  查看    

嗯 正好用上 收藏 Thx
2004-12-28 09:35 | guoadou      

#2楼[楼主]   回复  引用  查看    

如果__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; 
}
 
2005-01-17 14:11 | birdshome      

#3楼   回复  引用    

好,经典。收藏
2005-01-20 11:54 | daniel

#4楼   回复  引用    

没有看到啊,这个函数的定义在哪里?
2005-04-01 09:50 | wearebug

#5楼[楼主]   回复  引用  查看    

忘了更新这个文档了
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);
    }

    
if ( xmlhttp.status == 200 )
    {
        
return xmlhttp.responseText;
    }
    
return '';
},
2005-04-01 10:12 | birdshome      

#6楼   回复  引用    

我正在看你的代码,很多js的用法我以前没有接触过,写的真不错。
我已经加了birdshome@hotmail.com这个MSN,不知道是不是你的。
我把你贴出来的文档整理了,但是还是运行不起来,页面上什么都没有显示,正在郁闷中。
你的那个rar还挺唬人的,呵呵,我已经知道那是什么了。
2005-04-01 10:38 | wearebug

#7楼[楼主]   回复  引用  查看    

TreeView的代码还没有写完,所以我没有提供一个好的版本,现在给出的也只是为了演示效果。
// 我的msn不是这个,是:zhilee[at]msn.com。
2005-04-01 10:47 | birdshome      

#8楼   回复  引用  查看    

非常好。thanks
2005-09-08 01:20 | 木野狐      

#9楼   回复  引用  查看    

真是太好了。。。
2006-10-16 16:47 | 差劲的程序员      

#10楼   回复  引用  查看    

很不错的文章,不过我太明白这个javascript写的是一个类还是什么?怎么每人函数之前都是用逗号分割的?
2008-07-30 15:18 | stg609      



发表评论

昵称: [登录] [注册]

主页:

邮箱:(仅博主可见)

评论内容:

  登录  注册

[使用Ctrl+Enter键快速提交评论]

0 82274




相关文章:

相关链接: