我遇到了一个非常不寻常的问题。如有必要,为了更好地了解整体情况,请参阅我的上一篇文章Unable to retrieve a sub-NodeList from a NodeList in Javascript。
嗯,现在可以使用,但是当我尝试使用基本相同的方法解析不同的XML字符串时,生成的NodeList将不包含任何文本节点。而不是格式化的XML,我将发布我试图解析为NodeList的部分字符串:
<clients><client><code>1111</code><crm>2222</crm><company><name>FOO</name><enterprise>BAR</enterprise><cnpj>XXX</cnpj></company></client></clients>
请注意,这些不是节点的实际值,但是父节点客户端遵循这个结构(虽然它的方式很简陋)。
因此,出于测试目的,我最终使用以下代码来查看列表是否正确创建:
function parseClientsXML(xmlString, filter){
var parser = new DOMParser();
var xmlDoc = parser.parseFromString(xmlString, "text/xml");
var clients = xmlDoc.getElementsByTagName(filter);
for(var i = 0; i < clients.length; i++){
var client = clients[i].childNodes;
for (var j = 0; j < client.length; j++){
var node = client[j];
$('#div_clients').append("Node index: " + i + " - Type: " + node.nodeType + " - Name: " + node.nodeName + "<br>");
}
}
调用函数:
parseXML(theString, "clients");
我期望的结果是:
Node index: 0 - Type: 1 - Name: client
Node index: 1 - Type: 1 - Name: code
Node index: 2 - Type: 3 - Name: #text
Node index: 3 - Type: 1 - Name: crm
Node index: 4 - Type: 3 - Name: #text
等等。使用从我的其他帖子中的XML解析为“theString”的字符串,它工作正常。但是这篇文章中字符串的输出是这样的:
Node index: 0 - Type: 1 - Name: client
Node index: 1 - Type: 1 - Name: code
Node index: 2 - Type: 1 - Name: crm
Node index: 3 - Type: 1 - Name: company
Node index: 4 - Type: 1 - Name: name
...
我整天都在努力,但无法找到解决方案。输入字符串与我上面发布的字符串完全一样(好吧,不完全一样,但它很接近)。有什么想法吗?
答案 0 :(得分:2)
按照承诺解决您的问题。
function parseClientsXML(xmlString, filter) {
var parser = new DOMParser();
var xmlDoc = parser.parseFromString(xmlString, "text/xml");
(function output(node, filter) {
var child;
var children = node.childNodes.length;
if (filter === "") {
$('#div_clients').append(node.nodeType + " : " + node.nodeName + "<br>");
} else {
filter = node.nodeName === filter ? "" : filter;
}
for (child = 0; child < children; child += 1) {
output(node.childNodes[child], filter);
}
}(xmlDoc, filter));
}