JS—XML(跨浏览器)

跨浏览器解决方案

  • 分析存在的兼容性
    1、load()只有IE,Firefox,Opera支持,所以无法跨浏览器。
    2、获取XMLDOM对象的顺序问题,先判断现金的dom2,然后再去判断落后的IE
    3、针对不同的浏览器使用不同的序列化
    4、针对不同的报错进行不同的报错机制。

  • 逐个编写

  • 获得xmlDOM对象
    function createXmlDocument(){
    if(typeof arguments.callee.activeXString!="string"){
    var versions=["MSXML2.DOMDocument.6.0","MSXML2.DOMDocument.3.0","MSXML2.DOMDocument"];
    for(var i=0;i<versions.length;i++){
    try {
    new ActiveXObject(versions[i]);
    arguments.callee.activeXString=versions[i];
    break;
    }catch(e){
    //跳过
    }
    }
    }
    return new ActiveXObject(arguments.callee.activeXString);
    }
    function getXMLDOM(xmlstr){
    var xmlDom=null;
    if(typeof window.DOMParser!="undefined"){
    xmlDom=(new DOMParser()).parseFromString(xmlstr,'text/xml');
    var errors=xmlDom.getElementsByTagName('parsererror');
    if(errors.length){
    throw new Error("XML parsing Error:"+errors[0].textContent)
    }
    }else if(typeof window.ActiveXObject!="undefined"){
    xmlDom=createXmlDocument();
    xmlDom.loadXML(xmlstr);
    if(xmlDom.parseError){
    throw new Error("XML parsing Error:"+xmlDom.parseError.reason);
    }
    }else{
    throw new Error("抱歉,您的浏览器不支持xmlDOM对象。");
    }
    return xmlDom;
    }
    var xmlDom=getXMLDOM("<root><user/>doo<user></root>");
    alert(xmlDom);

  • 序列化dom对象

        function serializeXML(xmlDom){
            var xml="";
            if(typeof window.XMLSerializer!='undefined'){
                xml=(new XMLSerializer()).serializeToString(xmlDom);
            }else if(typeof xmlDom.xml !="undefined"){
                xml=xmlDom.xml;
            }else{
                throw new Error("抱歉,您的浏览器不支持xmlDOM对象。");
            }
            return xml;
        }
        var xmlDom=getXMLDOM("<root><user>doo</user></root>");
        alert(serializeXML(xmlDom));
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 个人博客:https://yeaseonzhang.github.io 花了半个多月的时间,终于又把“JS红宝书”...
    Yeaseon阅读 1,790评论 2 23
  • 因为浏览器之间行为的差异,多数JavaScript 代码包含了大量的if 语句,将执行引导到正确的代码中。看看下面...
    Daniel_Y阅读 407评论 0 1
  • XML:Extensible Markup Language(可扩展标记语言)是SGML(标准通用标记语言)的子集...
    Miss____Du阅读 1,064评论 0 5
  • HTML HTML5标签 媒体查询head部分写法 Doctype作用? 严格模式与混杂模式如何区分?它们有何意义...
    Mayo_阅读 671评论 0 8
  • “多大的团队最难带领?”这个问题我问过很多管理者,有人说几千人,有人答几万人,还有人回应管理不同区域的团队,我认为...
    怡跃阅读 830评论 2 4