如何使用Javascript从XML文档中提取值

时间:2011-03-24 06:17:21

标签: javascript xml

我正在尝试从xml文档中提取值并打印它们。 我还想计算孩子的数量(子节点) 每个节点都有。这是第一个标签有2个子标签,第二个标签有3个。

这是XML文档

<?xml version="1.0" ?> 
  <A>
  <a1>a1</a1> 
  <a2>a2</a2> 
  <B>
  <C>2</C> 
  <C>3</C> 
  </B>
  <B>
  <C>4</C> 
  <C>5</C> 
  <C>6</C>
  </B>
  </A>

这是我的JAVASCRIPT文件

if (window.XMLHttpRequest)
  {// code for IE7+, Firefox, Chrome, Opera, Safari
  xmlhttp=new XMLHttpRequest();
  }
else
  {// code for IE6, IE5
  xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
  }
xmlhttp.open("GET","extractexample.xml",false);
xmlhttp.send();
xmlDoc=xmlhttp.responseXML;
xmlObj=xmlDoc.documentElement;
document.write(xmlDoc.getElementsByTagName("B")[0].childNodes[0].nodeValue);

1 个答案:

答案 0 :(得分:2)

Element.childNodes方法返回所有类型的节点,包括空白文本节点。它可能不是你想要的。如果您只关心子元素的数量,请使用childElementCount

var b = xmlDoc.getElementsByTagName("B")[0];
alert(b.childElementCount); //should output 2

我没有尝试在IE中,它可能无法正常工作。 否则,如果您需要元素列表,请使用非HTML文档不支持的children children。你可以尝试这个功能:

function getChildren(element) {
  var nodes = element.childNodes;
  var children = [];
  for (var i = 0; i < nodes.length; i++) {
    if (nodes[i].nodeType == Node.ELEMENT_NODE) children.push(nodes[i]);
  }
  return children;
}

getChildren(b).length;