• Ajax应用篇

    2006-01-02

    版权声明:转载时请以超链接形式标明文章原始出处和作者信息及本声明
    http://sanlg.blogbus.com/logs/1779294.html

    看到一篇好文章了.做PHP时看过,但是没引起俺的太多注意.今天在处理XMLHttpRequest对像的多浏览器兼容性时找到了.

    <>
    EasyChen / 文


    什么是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);

    }
    函数的调用方法如下所示:
    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' );
    将转码后的字符输出就可以看见正确显示的中文了。

    其实呢,最里对我重要的是后面的responseTXT和responseXML的字符集的问题.前面俺做的一个应用里面老是乱码.后来我把那页的HTML编码格式改成UTF-8就OK了.
    现在证实了.

    关于 xmlhttp 部分,对于 GB2312 中文乱码的问题,除了通过服务器 PHP 转码之外,还可以通过 xmlHttp.responseXML 代替 xmlHttp.responseText 去获取服务器的数据,不过使用 responseXML 的话,服务器端需要输出 XML 代码,这时就可以用 encoding="gb2312" 了,不需要再转码了。


    收藏到:Del.icio.us