web-dev-qa-db-ja.com

クロスブラウザJavascript XML解析

JavascriptでXMLファイルを解析するためのクロスブラウザ/クロスプラットフォームの方法はありますか?

62
sazr

以下は、IE 6を含む、すべての主要なブラウザーで動作します。

var parseXml;

if (typeof window.DOMParser != "undefined") {
    parseXml = function(xmlStr) {
        return ( new window.DOMParser() ).parseFromString(xmlStr, "text/xml");
    };
} else if (typeof window.ActiveXObject != "undefined" &&
       new window.ActiveXObject("Microsoft.XMLDOM")) {
    parseXml = function(xmlStr) {
        var xmlDoc = new window.ActiveXObject("Microsoft.XMLDOM");
        xmlDoc.async = "false";
        xmlDoc.loadXML(xmlStr);
        return xmlDoc;
    };
} else {
    throw new Error("No XML parser found");
}

使用例:

var xml = parseXml("<foo>Stuff</foo>");
alert(xml.documentElement.nodeName);

ライブデモ:

var parseXml;

if (typeof window.DOMParser != "undefined") {
    parseXml = function(xmlStr) {
        return ( new window.DOMParser() ).parseFromString(xmlStr, "text/xml");
    };
} else if (typeof window.ActiveXObject != "undefined" &&
       new window.ActiveXObject("Microsoft.XMLDOM")) {
    parseXml = function(xmlStr) {
        var xmlDoc = new window.ActiveXObject("Microsoft.XMLDOM");
        xmlDoc.async = "false";
        xmlDoc.loadXML(xmlStr);
        return xmlDoc;
    };
} else {
    throw new Error("No XML parser found");
}

var xml = parseXml("<foo>Stuff</foo>");
document.body.innerHTML = "Root element: " + xml.documentElement.nodeName;
62
Tim Down

jQuery.parseXML の使用を検討してください。

古いJQueryのコード(2.xより前)は、受け入れられた回答で提案されたものと本質的に同じであり、 http://code.jquery.com/jquery-1.9.1.js で見つけることができます。 、以下の部分バージョン:

// Cross-browser xml parsing
parseXML: function( data ) {
    ...
    try {
        if ( window.DOMParser ) { // Standard
            tmp = new DOMParser();
            xml = tmp.parseFromString( data , "text/xml" );
        } else { // IE
            xml = new ActiveXObject( "Microsoft.XMLDOM" );
            xml.async = "false";
            xml.loadXML( data );
        }
    } catch( e ) {
        xml = undefined;
    }
    ...
}

JQuery 2.xの開始コードは、ActiveXブランチをスキップするように変更されています(まだ必要な場合)。古いバージョンのJQueryまたはインラインActiveX解析を使用してください。 http://code.jquery.com/jquery-2.0.0.js からの部分的なコード:

// Cross-browser xml parsing
parseXML: function( data ) {
    var xml, tmp;
    .....
    // Support: IE9
    try {
        tmp = new DOMParser();
        xml = tmp.parseFromString( data , "text/xml" );
    } catch ( e ) {
        xml = undefined;
    }
    .....
},
6
Alexei Levenkov

メモリ内に完全に保持できない可能性がある大きなXMLドキュメントを解析する必要がある場合は、次のようなSAXスタイルパーサーの使用を検討してください。 https://github.com/isaacs/sax-js/ =

4
Janus Troelsen