构建一个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的实现代码如下:

#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)的回调函数。比如:

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

本文转自博客园鸟食轩的博客,原文链接:http://www.cnblogs.com/birdshome/,如需转载请自行联系原博主。

目录
相关文章
|
4月前
|
JavaScript API
前后端数据交互.js文件的axios的写法,想要往后端发送数据,页面注入API,await的意思是同步等待服务器数据,并返回,axios注入在其他页面,其他页面调用的时候,同步作用
前后端数据交互.js文件的axios的写法,想要往后端发送数据,页面注入API,await的意思是同步等待服务器数据,并返回,axios注入在其他页面,其他页面调用的时候,同步作用
|
5月前
|
Web App开发 移动开发 安全
如何做到修改 url 参数页面不刷新
如何做到修改 url 参数页面不刷新
|
6月前
|
数据安全/隐私保护
Session 管理以及Cookie 应用最简单实例
Session 管理以及Cookie 应用最简单实例
|
JSON 前端开发 API
新建一个uniapp请求,并且封装request
新建一个uniapp请求,并且封装request
40 1
|
前端开发 PHP
php解决ajax使用post请求时提交的数据过多而导致et::ERR_CONNECTION_RESET的解决方案
php解决ajax使用post请求时提交的数据过多而导致et::ERR_CONNECTION_RESET的解决方案
191 0
|
XML JSON 前端开发
Qt+QtWebApp开发笔记(五):http服务器html中使用json触发ajax与后台交互实现数据更新传递
前面完成了页面的跳转、登录,很多时候不刷新页面就想刷新局部数据,此时ajax就是此种技术,且是异步的。   本篇实现网页内部使用js调用ajax实现异步交互数据。   在js中使用 ajax是通过XMLHttpRequest来实现的。
|
Java
会话技术概述、Cookie常用属性和方法及Session常用方法和生命周期
会话技术概述、Cookie常用属性和方法及Session常用方法和生命周期
176 0
|
SQL JavaScript 前端开发
两个相同的负载user在一起启动的时候,造成相关接口调用第一次报异常 调用第二次正常 如此反反复复 解决方法;mysql复习、JavaScript HTML BOM和DOM触发监听机制事件
两个相同的负载user在一起启动的时候 造成相关接口调用第一次报异常 调用第二次正常 如此反反复复 解决方法 放掉一个实例个数
142 0
两个相同的负载user在一起启动的时候,造成相关接口调用第一次报异常 调用第二次正常 如此反反复复 解决方法;mysql复习、JavaScript HTML BOM和DOM触发监听机制事件
|
前端开发
前端工作总结142-element上传组件时候的钩子--event里面有数据参数
前端工作总结142-element上传组件时候的钩子--event里面有数据参数
75 0
前端工作总结142-element上传组件时候的钩子--event里面有数据参数