DOMParser.parseFromString因XML5619而失败:文档语法不正确

时间:2014-02-17 20:42:26

标签: javascript

我有这个javascript函数从网站获取xml文件:

function getCCDfromHV() {
    var xmlhttp;
    if (window.XMLHttpRequest) xmlhttp=new XMLHttpRequest(); // code for IE7+, Firefox, Chrome, Opera, Safari
    else xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");// code for IE6, IE5
    xmlhttp.onreadystatechange=function() {
        if (xmlhttp.readyState==4 && xmlhttp.status==200) {
            var xml = xmlhttp.responseText;  
            document.getElementById("uploadResponse").innerHTML=xml;
            xmlDom = createXmlDOM(xml);
        }
    }
    xmlhttp.open("GET","../HVRawConnectorPHP/demo_app/GetCCDfromHV.php",true);   
    xmlhttp.send();
}

从转储到.innerHTML我可以看到xml被检索好了。但是createXmlDOM的parseFromString失败,出现“XML5619:不正确的文档语法”,如下所示:

function createXmlDOM(xml) {
    console.log('createXmlDOM: the first 255 chars=' +xml.substring(0,255));
    if (window.DOMParser){
        var parser=new DOMParser();
        xmlDom=parser.parseFromString(xml,"text/xml");    //fails with XML5619: Incorrect document syntax.
    }
    else { // Internet Explorer
        xmlDom=new ActiveXObject("Microsoft.XMLDOM");
        xmlDom.async=false;
        xmlDom.loadXML(xml);
    }
    return xmlDom;
}

但是如果我复制.innerHTML文本并将其粘贴到编辑器中并将其保存为文本文件,使用FileReader加载该文件,然后将该文本发送到createXmlDOM,它工作正常!

因此,某种方式切割和粘贴或文件写入和读取的行为会进行某种翻译,使得parseFromString可以接受。有没有办法在不保存和重新加载文件的情况下执行此操作?似乎是第一个角色失败的是'&'因为第一个字母真的是'<'但是html将其更改为& lt,而从文本文件加载它不会。

1 个答案:

答案 0 :(得分:1)

我终于明白了。 xml需要进行html解码。我添加了以下功能:

function htmlDecode(input){
  var e = document.createElement('div');
  e.innerHTML = input;
  return e.childNodes.length === 0 ? "" : e.childNodes[0].nodeValue;
}

我从这里找到的: http://css-tricks.com/snippets/javascript/unescape-html-in-js/