Xpath简单的问题

时间:2011-06-06 11:26:01

标签: xml xpath

以下代码适用于已保存的XML文件,但不会解析HTML。

<html>
<body>
<script type="text/javascript">
function loadXMLDoc(dname)
{
if (window.XMLHttpRequest)
  {
  xhttp=new XMLHttpRequest();
  }
else
  {
  xhttp=new ActiveXObject("Microsoft.XMLHTTP");
  }
xhttp.open("GET",dname,false);
xhttp.send("");
return xhttp.responseXML;
}

xml=loadXMLDoc("test.html");
path="div[@id='aa']/span[@class]//a[@href]"
// code for IE
if (window.ActiveXObject)
{
var nodes=xml.selectNodes(path);

for (i=0;i<nodes.length;i++)
  {
  document.write(nodes[i].childNodes[0].nodeValue);
  document.write("<br />");
  }
}
// code for Mozilla, Firefox, Opera, etc.
else if (document.implementation && document.implementation.createDocument)
{
var nodes=xml.evaluate(path, xml, null, XPathResult.ANY_TYPE, null);
var result=nodes.iterateNext();

while (result)
  {
  document.write(result.childNodes[0].nodeValue);
  document.write("<br />");
  result=nodes.iterateNext();
  }
}
</script>

</body>
</html>

test.html看起来像这样

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
      "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
    <head>
 <meta http-equiv="Content-Type" content="text/html"; charset="UTF-8" />
    </head>
    <body>
    <div id="aa">
        <span class="bb">
            <a href="http://google.com">link 1</a>
        </span>
    </div>
        </body>
        </html>

1 个答案:

答案 0 :(得分:1)

我对“Microsoft.XMLHTTP”一无所知,但我怀疑如果要使用XML解析器,则需要用XHTML替换HTML。普通HTML不遵守XML的所有规则(例如,您可以使用未封闭的标记,例如<br>)。