今天是  80酷酷网已完成全部制作,并坚持每天更新,欢迎提供好的意见或建议!

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

来源:80酷酷网  更新时间:2010-07-05  点击:123

  xml|心得    最近研究了一下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,否则会出错。



上一篇:使用XML DOM生成XML(3)     下一篇:将改变我们生活的这些XML应用

相关文章
最新评论     查看全部评论
发表评论
  不能超过500字节,请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论,否则后果自负。