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

博客介绍了__XmlHttpPool__与服务器通信的方法,有GET和POST两种。使用方式为__XmlHttpPool__.GetRemoteData(url, callback)或__XmlHttpPool__.PostRemoteData(url, callback, data),其中url是服务器地址,callback是处理返回数据的回调函数。
在页面上使用ActiveXObject的代价是很大的,如果我们的无刷新页面使用 xmlhttp技术,我们或许需要频繁的建立xmlhttp对象,当然我们也可以使用全局变量来cache一个xmlhttp对象实例。但是这样的方法适合于同步方式xmlhttp通信,而对于异步方式xmlhttp通信将会出现问题。由于没有了进程的堵塞,用户可能再次调用同一个xmlhttp实例,如果这时前一个通信未完成,那么就失败了。

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

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


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

< scrip 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>

posted on 2004-12-27 21:38 birdshome 阅读(2021) 评论(8)  编辑 收藏 收藏至365Key 所属分类: JScript&DHTML开发

评论

# re: 构建一个pool来管理无刷新页面的xmlhttp对象    嗯 正好用上 收藏 Thx
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; 
}
 
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);
     }

    
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对象   

非常好。thanks
2005-09-08 01:20 | 木野狐
#  re: 构建一个pool来管理无刷新页面的xmlhttp对象    嗯 正好用上 收藏 Thx
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; 
}
 
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);
     }

    
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对象   

非常好。thanks
2005-09-08 01:20 | 木野狐
同步定位与地图构建(SLAM)技术为移动机器人或自主载具在未知空间中的导航提供了核心支撑。借助该技术,机器人能够在探索过程中实时构建环境地图并确定自身位置。典型的SLAM流程涵盖传感器数据采集、数据处理、状态估计及地图生成等环节,其核心挑战在于有效处理定位与环境建模中的各类不确定性。 Matlab作为工程计算与数据可视化领域广泛应用的数学软件,具备丰富的内置函数与专用工具箱,尤其适用于算法开发与仿真验证。在SLAM研究方面,Matlab可用于模拟传感器输出、实现定位建图算法,并进行系统性能评估。其仿真环境能显著降低实验成本,加速算法开发与验证周期。 本次“SLAM-基于Matlab的同步定位与建图仿真实践项目”通过Matlab平台完整再现了SLAM的关键流程,包括数据采集、滤波估计、特征提取、数据关联与地图更新等核心模块。该项目不仅呈现了SLAM技术的实际应用场景,更为机器人导航与自主移动领域的研究人员提供了系统的实践参考。 项目涉及的核心技术要点主要包括:传感器模型(如激光雷达与视觉传感器)的建立与应用、特征匹配与数据关联方法、滤波器设计(如扩展卡尔曼滤波与粒子滤波)、图优化框架(如GTSAM与Ceres Solver)以及路径规划与避障策略。通过项目实践,参与者可深入掌握SLAM算法的实现原理,并提升相关算法的设计与调试能力。 该项目同时注重理论向工程实践的转化,为机器人技术领域的学习者提供了宝贵的实操经验。Matlab仿真环境将复杂的技术问题可视化与可操作化,显著降低了学习门槛,提升了学习效率与质量。 实践过程中,学习者将直面SLAM技术在实际应用中遇到的典型问题,包括传感器误差补偿、动态环境下的建图定位挑战以及计算资源优化等。这些问题的解决对推动SLAM技术的产业化应用具有重要价值。 SLAM技术在工业自动化、服务机器人、自动驾驶及无人机等领域的应用前景广阔。掌握该项技术不仅有助于提升个人专业能力,也为相关行业的技术发展提供了重要支撑。随着技术进步与应用场景的持续拓展,SLAM技术的重要性将日益凸显。 本实践项目作为综合性学习资源,为机器人技术领域的专业人员提供了深入研习SLAM技术的实践平台。通过Matlab这一高效工具,参与者能够直观理解SLAM的实现过程,掌握关键算法,并将理论知识系统应用于实际工程问题的解决之中。 资源来源于网络分享,仅用于学习交流使用,请勿用于商业,如有侵权请联系我删除!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值