关于最近研究XmlHttp的一些心得

最近研究了一下xmlhttp,还是很有意思的东东。我喜欢让它在IE6和firefox中都运行正常,后台用的是dom4j进行解析。

1.下载 http://webfx.eae.net/dhtml/xmlextras/xmlextras.zip 包,里面有个xmlextras.js,把它拿出来,我用来生成XmlHttp对象。
2.在xmlextras.js中加上以下代码:
// check browsers
var ua      = navigator.userAgent;
var opera   = /opera [56789]|opera//[56789]/i.test(ua);
var ie      = !opera && /msie [56789]/i.test(ua);       // preventing opera to be identified as ie
var mozilla = !opera && /mozilla//[56789]/i.test(ua);   // preventing opera to be identified as mz
/* end browser checks */
if(mozilla) {
    XMLDocument.prototype.selectSingleNode = function(tagname) {
        var result = this.evaluate(tagname, this, null, 0, null);
        return result.iterateNext();
    }
    XMLDocument.prototype.selectNodes = function(tagname) {
        var result = this.evaluate(tagname, this, null, 0, null);
        var xns = new XMLNodes(result);
        return xns;
    }
    //定义一个新的类以兼容 IE 中 selectNodes() 的返回类型。
    function XMLNodes(result) {
        this.length = 0;
        this.pointer = 0;
        this.array = new Array();
        var i = 0;
        while((this.array[i]=result.iterateNext())!=null)
            i++;
        this.length = this.array.length;
    }
    XMLNodes.prototype.nextNode = function() {
        this.pointer++;
        return this.array[pointer-1];
    }
    XMLNodes.prototype.reset = function() {
        this.pointer = 0;
    }
}
让firefox支持和IE一样的一些接口。




3.XmlHttp返回之后,如果需要XmlHttp.responseXML对象,在firefox中一切正常,但是在ie6中就不常了,
所以需要,重新 new 一个 XmlDocument:

var doc = XmlDocument.create();
doc.loadXML(xmlHttp.responseText);



4.用 xsl 翻译 xml ,如果想要保留空格,需要加上 xml:space="preserve",例如:
<xsl:for-each select="parameter" xml:space="preserve">


5.在 firefox 中 xmlHttp.open("POST", url, true); 最后的一个参数不能为 false,否则会出错。


6.参考
http://webfx.eae.net/dhtml/xmlextras/xmlextras.html
http://www.w3.org/Style/XSL/
http://www.w3.org/TR/xslt XSL Transformations (XSLT) Version 1.0
http://www.mozilla.org/xmlextras/xmldataislands/








评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值