
Xmlhttp是一种浏览器对象, 可用于模拟http的GET和POST请求。配合JavaScript可以实现页面来自数据在无刷新下的定时数据更新,如果应360百科用在聊天室、文字直播上可以取得较好的视觉效果。
- 外文名称 XMLHTTP
- 性质 浏览器对象
XmlHttp对象介绍
在IE中XmlHt来自tp被实现为ActiveX对象,通常使用var xm球肉放的雨预lhttp = new ActiveXObject("Msxml2.XMLHTTP");也可以使360百科用var xmlhttp = 沿促求换将求象洲终仍夜createobject("MiCROSOFT.XMLHTTP") 来创建一个对象,然后使用该对象的open方法来发出一个Http请求。
xmlhttp.open("GET", fragment_url);
这时候浏览器已经发出了Http请求,我们需要注册一个匿名价投二卷计信控深点函数给XmlHttp对象的onreadystatechange方法,这样当请求返回时,xmlhttp就会自动调用我们注册的这个函数,下边是一个实际的例子。
xml者http.onreadystatechange = function()
{
if (xmlhttp.readyState == 4 && xmlhttp.status == 200)
{
element.innerHTML = xmlhttp.responseText;
甲案读}
}
因为我们不需要再发送任何信息,所以用下边的语理充独吸五万句结束
xmlhttp.send(null);
我们将上边的过程封装为一个函数,下边是这个函数的完整代码:
function load内值示施直局FragmentInToElement(fragmen什汉调简抓孔卫t_url, element_id)
{
var element = document.getElementById(element_id);
varxmlhttp = new ActiveXObject("Msxml2.XMLH色反掌伯剧奏知TTP");
xmlhttp.open("GET", fragment_url);
xmlhttp.onreadystatechange = func盾口更得水西田候例这tion()
{
i固管克鲁父转笔f (xmlhttp.readyState == 普缩4 && xmlhttp.sta买晶饭决副银越tus == 200)
{
element.innerHTML = xmlhttp.responseTe染侵给都仅妈季世族快伤xt;
}
}
xmlhttp.send(null);
PHPMORE VOL5 合实24/26
}
函数调用例子如下:
loadFragmentI云步贵热政引干候nToElement( 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并不要求,这是一个很需要注意的问题。
实现XmlHttp的跨浏览器应用
为了能在多种浏览器上有一个统一括实的实现, 我们可以用JavaScript来对陈不同浏览器的差异进行封装。 这里我们采用Andrew G来自regory的实现。首先我们要引用Andrew Gregory的一个名为xmlhttprequest.js的Js脚本。
然后在创建XmlHttp对象时统一落滑使用new XMLHttpRequest()就可以了; 其它的方法不用改变。 这个际Js脚本运行我们在IE、 Gecko(Mozilla/FireFox) 和Opera的特定版本使用XmlHttp。下边是调整后的loadFragmentInToElement函数, 这个函数在IE6和FireFox1.0pre上运行殖界通过。
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 );
将转码后的字符输出普首话就可以看见正确显示的中文
评论留言