0

我一直在关注 w3 学校关于使用 xpath 浏览我的 xml 文档的示例,但是我从 iterateNext() 返回的所有内容都是空的。下面是我的 blog.xml 文件。

<blog
xmlns ="http://www.w3schools.com" 
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="blogschema.xsd">
<Title>My blog</Title>

<Entry>
    <Heading id="101">week1</Heading>   
    <body>
        <text>enter text right here</text>
        <pictures>pictures in the body</pictures>

    </body>
    <labels>Seperate labels with commas</labels>
    <date> 20121119</date>

</Entry>





</blog>

这是我的 html 脚本,while 语句永远不会到达,因为结果总是返回 null,这可能是我忽略的东西,但我认为如果它在 w3 学校它应该真的有效。

xmlDoc=loadXMLDoc("blog.xml");//loads xml file  
//loadXmlContent(xmlDoc); using xml dom

path="/blog/Title"
if(document.implementation && document.implementation.createDocument)
{

    var nodes = xmlDoc.evaluate(path, xmlDoc, null, 5, null);
    alert(nodes);
    var result = nodes.iterateNext();


    while (result)
    {document.write(result.childNodes[0].nodeValue);}

}
</script>
4

1 回答 1

2

输入中有一个默认命名空间声明xmlns="http://www.w3schools.com",您需要考虑例如

var nodes = xmlDoc.evaluate("df:blog/df:Title", xmlDoc, function(prefix) { if (prefix === "df") return "http://www.w3schools.com"; }, 5, null);

var result;

while ((result = nodes.iterateNext()) != null)
{
  document.write(result.textContent);
}
于 2012-12-31T15:05:03.673 回答