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上运行通过。
xmlhttprequest.js文件和具体的使用例子可以在我写的一个demo中找到。
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 );
将转码后的字符输出就可以看见正确显示的中文[@more@]
新,如果应用在聊天室、文字直播上可以取得较好的视觉效果。
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上运行通过。
xmlhttprequest.js文件和具体的使用例子可以在我写的一个demo中找到。
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 );
将转码后的字符输出就可以看见正确显示的中文[@more@]
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/7558084/viewspace-1004411/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/7558084/viewspace-1004411/