当前位置: 首页 > 图文教程 > 网络编程 > PHP > 建一个XMLHttpRequest对象池

PHP
利用PHP+JavaScript打造AJAX搜索窗(1)
利用PHP+JavaScript打造AJAX搜索窗(2)
利用PHP+JavaScript打造AJAX搜索窗(3)
利用PHP+JavaScript打造AJAX搜索窗(4)
AJAX 技术在 PHP 中的简单使用(1 )
AJAX 技术在 PHP 中的简单使用(2)
PHP 中使用 crypt() 实现用户身份验证
PHP 下一代的五个 framework 介绍
利用PHP的OOP特性实现数据保护(1 )
利用PHP的OOP特性实现数据保护(2)
利用PHP的OOP特性实现数据保护(3)
小技巧:Windows下PHP与SQL Server的连接
如何利用PHP自定义错误处理器处理出错信息
利用正确的PHP类搜索定位目录树
如何使用PHP和PEAR的Net:Geo定位用户
AJAX应用中浏览器的BACK后退按钮问题
如何用PHP程序控制浏览器cache
PHP入门教程:如何制作一个小桌子
巧用PHP文本模板读取编写XML DOM
PHP实现简单线性回归之数学库重要性

PHP 中的 建一个XMLHttpRequest对象池


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-11-03   浏览: 114 ::
收藏到网摘: n/a

在ajax应用中,通常一个页面要同时发送多个请求,如果只有一个XMLHttpRequest对象,前面
的请求还未完成,后面的就会把前面的覆盖掉,如果每次都创建一个新的XMLHttpRequest对象,
也会造成浪费。解决的办法就是创建一个XMLHttpRequset的对象池,如果池里有空闲的对象,
则使用此对象,否则将创建一个新的对象。
下面是我最近写的一个简单的类:

/**
 * XMLHttpRequest Object Pool
 *
 * @author    legend <[email protected]>
 * @link      http://www.ugia.cn/?p=85
 * @Copyright www.ugia.cn
 */
   
var XMLHttp = {
    _objPool: [],
   
    _getInstance: function ()
    {
        for (var i = 0; i < this._objPool.length; i ++)
        {
            if (this._objPool[i].readyState == 0 || this._objPool[i].readyState == 4)
            {
                return this._objPool[i];
            }
        }
   
        // IE5中不支持push方法
        this._objPool[this._objPool.length] = this._createObj();
   
        return this._objPool[this._objPool.length - 1];
    },
   
    _createObj: function ()
    {
        if (window.XMLHttpRequest)
        {
            var objXMLHttp = new XMLHttpRequest();
   
        }
        else
        {
            var MSXML = ['MSXML2.XMLHTTP.5.0', 'MSXML2.XMLHTTP.4.0',
                  'MSXML2.XMLHTTP.3.0', 'MSXML2.XMLHTTP', 'Microsoft.XMLHTTP'];
            for(var n = 0; n < MSXML.length; n ++)
            {
                try
                {
                    var objXMLHttp = new ActiveXObject(MSXML[n]);
                    break;
                }
                catch(e)
                {
                }
            }
         }