Xmlhttp小记

来源:互联网 发布:网站域名要服务器吗 编辑:程序博客网 时间:2024/05/18 01:06

Xmlhttp是一种浏览器对象, 可用于模拟http的GET和POST请求。配合JavaScript可以实现页面数据在无刷新下的定时数据更新,如果应用在聊天室、文字直播上可以取得较好的视觉效果。

 

IE中的 XmlHttp对象

 

在IE中XmlHttp被实现为ActiveX对象,通常使用:

 

var xmlhttp = new ActiveXObject("Msxml2.XMLHTTP");

 

来创建一个对象,然后使用该对象的open方法来发出一个Http请求。

 

xmlhttp.open("GET", fragment_url);

 

这时候浏览器已经发出了Http请求,我们需要注册一个匿名函数给XmlHttp对象的onreadystatechange方法,这样当请求返回时,xmlhttp就会自动调用我们注册的这个函数,下边是一个实际的例子。

 

xmlhttp.onreadystatechange = function()

{

if (xmlhttp.readyState == 4 && xmlhttp.status == 200)

{

element.innerHTML = xmlhttp.responseText;

}

}

 

因为我们不需要再发送任何信息,所以用下边的语句结束

 

xmlhttp.send(null);

 

我们将上边的过程封装为一个函数,下边是这个函数的完整代码:

 

function loadFragmentInToElement(fragment_url, element_id)

{

var element = document.getElementById(element_id);

var xmlhttp = new ActiveXObject("Msxml2.XMLHTTP");

xmlhttp.open("GET", fragment_url);

xmlhttp.onreadystatechange = function()

{

if (xmlhttp.readyState == 4 && xmlhttp.status == 200)

{

element.innerHTML = xmlhttp.responseText;

}

}

xmlhttp.send(null);

PHPMORE VOL5 24/26

}

 

函数的调用方法如下所示:

 

loadFragmentInToElement( http://domain.com/url.php, DynamicContent_id );

 

有了上边的代码, 再配合JavaScript的定时函数, 我们就可以实现定时的无刷新数据更新了, 下边这个函数每隔5秒对element_id的数据进行一次更新。

 

function refresh( element_id )

{

loadFragmentInToElement( show.php , + element_id );

setTimeout( "refresh(ts)" , 5000 );

}

 

在 IE上使用XmlHttp要注意的问题

 

特别要注意的是由于IE的Cache的关系,我们看见的XmlHttp并不总是最新读取的那一个,为了让IE不启用Cache,我们发送给IE一个特殊的Header,用PHP实现如下:

 

header( "Expires: Mon, 26 Jul 1997 05:00:00 GMT" );

header( "Last-Modified: " . gmdate( "D, d M Y H:i:s" ) . "GMT" );

header( "Cache-Control: no-cache, must-revalidate" );

header( "Pragma: no-cache" );

 

XmlHttp对象在Gecko上的实现

 

Gecko上的XmlHttp和IE上略有不同,它并不需要通过ActiveX来创建。另外回调函数必须在open方法之前注册,而IE并不要求,这是一个很需要注意的问题。

 

使用JavaScript实现XmlHttp的跨浏览器应用,为了能在多种浏览器上有一个统一的实现,我们可以用JavaScript来对不同浏览器的差异进行封装。 这里我们采用Andrew Gregory的实现。首先我们要引用Andrew Gregory的一个名为xmlhttprequest.js的Js脚本。

 

然后在创建XmlHttp对象时统一使用new XMLHttpRequest()就可以了; 其它的方法不用改变。 这个Js脚本运行我们在IE、 Gecko (Mozilla/FireFox) 和Opera的特定版本使用XmlHttp。下边是调整后的loadFragmentInToElement函数, 这个函数在IE6 和FireFox1.0pre上运行通过。