gpt4 book ai didi

javascript - 我如何在 JavaScript 中循环遍历 XML 节点?

转载 作者:可可西里 更新时间:2023-11-01 02:05:38 25 4
gpt4 key购买 nike

我正在尝试遍历包含用户信息的 XML 节点,以在我的网站上创建一个 HTML 表格。

这是 XML 的样子:

<websites_name>
<user>...</user>
<user>...</user>
.
.
.
</websites_name>

这是我试图解析的代码:

for(var user in xmlhttp.getElementsByTagName('user')){   //fix this row to me
//Create a new row for tbody
var tr = document.createElement('tr');
document.getElementById('tbody').appendChild(tr);
}

更新

xmlhttp = new XMLHttpRequest();
xmlhttp.open("GET","some URL",true);
xmlhttp.send();
var xmlDoc = xmlhttp.responseXML;
var root = xmlDoc.getElementsByTagName('websites_name');
for(var i=0, i<root[0].childNodes.length,i++){
//Create a new row for tbody
var tr = document.createElement('tr');
document.getElementById('tbody').appendChild(tr);
}

最佳答案

在 JavaScript 中解析 XML 最不直观的事情之一是元素标签内的文本实际上是您必须遍历的节点。

假设它是 <user>text data</user> ,您不仅必须遍历用户元素的文本节点以提取文本数据,还必须在 DOM 中创建一个包含该数据的文本节点才能看到它。参见 nodeValuecreatetextnode :

// get XML 
var xml = xhr.responseXML;

// get users
var users = xml.getElementsByTagName("user");
for (var i = 0; i < users.length; i++) {
var user = users[i].firstChild.nodeValue;
var tr = document.createElement("tr");
var td = document.createElement("td");
var textNode = document.createTextNode(user);
td.appendChild(textNode);
tr.appendChild(td);
document.getElementById("tbody").appendChild(tr);
}

关于javascript - 我如何在 JavaScript 中循环遍历 XML 节点?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4362392/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com