对XmlHttp研究的经验分享
本文提供给大家学习的是关于作者对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,否则会出错。