XmlHttp试用笔记

1 什么是XmlHttp Xmlhttp是一种浏览器对象,可用于模拟http的GET和POST请求。配合JavaScript可以实现页面数据在无刷新下的定时数据更新,如果应用在聊天室、文字直播上可以取得较好的视觉效果。 2 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); } 函数的调用方法如下所示: 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 ); } 3 在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" ); 4 XmlHttp对象在Gecko上的实现 Gecko上的XmlHttp和IE上略有不同,它并不需要通过ActiveX来创建。另外回调函数必须在open方法之前注册,而IE并不要求,这是一个很需要注意的问题。 5 使用JavaScript实现XmlHttp的跨浏览器应用 为了能在多种浏览器上有一个统一的实现,我们可以用JavaScript来对不同浏览器的差异进行封装。这里我们采用Andrew Gregory的实现。首先我们要引用Andrew Gregory的一个名为xmlhttprequest.js的Js脚本。 然后在创建XmlHttp对象时统一使用new XMLHttpRequest()就可以了;其它的方法不用改变。这个Js脚本运行我们在IE、Gecko(Mozilla/FireFox)和Opera的特定版本使用XmlHttp。下边是调整后的loadFragmentInToElement函数,这个函数在IE6和FireFox1.0pre上运行通过。 xmlhttprequest.js文件和具体的使用例子可以在我写的一个DEMO中找到。 6 XmlHttp中的中文乱码问题 在默认情况下,XmlHttp都是使用Utf-8字符集,而我们使用的多是GB2312字符集,这就要求我们进行GB2312到Utf-8的转码。PHP提供了一个可选的专码模块,可以实现多种字符集之间的相互转化。加载这个专码模块的方法如下: 打开PHP配置文件php.ini,将 ;extension=php_mbstring.dll(*nix是php_mbstring.so) 前的分号去掉。重新启动Apache以后,这个模块就可以使用了。如果有错误出现,请检查扩展目录的路径设置是否正确。 加载这个模块以后,我们就可以使用mb_convert_encoding函数来转码了: $utf8_string = mb_convert_encoding( $gb_string , 'UTF-8' , 'GB2312' ); 将转码后的字符输出就可以看见正确显示的中文了。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值