我有这个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,而从文本文件加载它不会。
答案 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/