建一個(gè)XMLHttpRequest對(duì)象池

字號(hào):

在ajax應(yīng)用中,通常一個(gè)頁面要同時(shí)發(fā)送多個(gè)請(qǐng)求,如果只有一個(gè)XMLHttpRequest對(duì)象,前面的請(qǐng)求還未完成,后面的就會(huì)把前面的覆蓋掉,如果每次都創(chuàng)建一個(gè)新的XMLHttpRequest對(duì)象,也會(huì)造成浪費(fèi)。解決的辦法就是創(chuàng)建一個(gè)XMLHttpRequset的對(duì)象池,如果池里有空閑的對(duì)象,則使用此對(duì)象,否則將創(chuàng)建一個(gè)新的對(duì)象。
    下面是我最近寫的一個(gè)簡單的類:
    /**
     * XMLHttpRequest Object Pool
     *
     * @author legend
     * @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)
     {
     }
     }
     }
     // mozilla某些版本沒有readyState屬性
     if (objXMLHttp.readyState == null)
     {
     objXMLHttp.readyState = 0;
     objXMLHttp.addEventListener("load", function ()
     {
     objXMLHttp.readyState = 4;
     if (typeof objXMLHttp.onreadystatechange == "function")
     {
     objXMLHttp.onreadystatechange();
     }
     }, false);
     }
     return objXMLHttp;
     },