为了更好地理解 textConent 和 nodeValue 之间的区别,我想了解为什么在我的代码中使用nodeValue不起作用。我有以下XML字符串,它通过jQuery回调通过AJAX加载。如果你查看循环的中心,如果我使用nodeValue代替textContent,该部分将产生一个空值。
XML
<?xml version="1.0" encoding="UTF-8"?>
<Sensors>
<Sensor>
<id>56</id>
<state>false</state>
</Sensor>
</Sensors>
我使用下面的函数来解析XML。
的JavaScript
function parseSensors(data,status,xhr) {
var xml = xhr.responseXML;
var sensors = xml.documentElement.childNodes;
var list="<ul>";
for(var i=0; i < sensors.length; i++) {
list= list +"<li>"+sensors[i].childNodes[0].textContent+"</li>";
}
list=list+"</u>";
document.getElementById("real-time_active_sensors").innerHTML=list;
}
答案 0 :(得分:1)
节点的文本部分实际上是节点本身的子节点。如果节点中没有数据,那么对childNodes [0] .nodeValue的调用将失败。在尝试访问之前,您需要检查实际存在多少个childNodes。否则,您需要强制执行一项协议,该协议要求在创建XML数据时不能包含空标记。