xmlhttp无刷新数据更新

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" );

 
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值