0

这是我关于堆栈溢出的第一个问题,希望你们能帮助我。

这是我的xml

<?xml version="1.0"?>
<RecentPhotoUploads>
<PHOTO><SOURCE>6171.jpg</SOURCE></PHOTO>
<PHOTO><SOURCE>6173.jpg</SOURCE></PHOTO>
<PHOTO><SOURCE>6895.jpg</SOURCE></PHOTO>
<PHOTO><SOURCE>Tulips.jpg</SOURCE></PHOTO>
</RecentPhotoUploads>

这是我的 javascript 代码

    var xml=loadXMLDoc("../upload.xml");
    var source="/RecentPhotoUploads/PHOTO/SOURCE"

    var nodes=xml.evaluate(source, xml, null, XPathResult.ANY_TYPE, null);
    var result=nodes.iterateNext();


                while (result)
                {
                document.write("<h2>" + result.childNodes[0].nodeValue + "</h2>");
                document.write("<a href='../pics/" + result.childNodes[0].nodeValue + "</a>");
                result=nodes.iterateNext();
                }

我将如何向后循环这个 xpathresult?

4

3 回答 3

2

为什么要向后导航?您可以向后打印...

var xml=loadXMLDoc("../upload.xml");
var source="/RecentPhotoUploads/PHOTO/SOURCE"

var nodes=xml.evaluate(source, xml, null, XPathResult.ANY_TYPE, null);
var result=nodes.iterateNext();

var buffer = "";
while (result) {
    buffer = "<h2>" + result.childNodes[0].nodeValue + "</h2>"
           + "<a href='../pics/" + result.childNodes[0].nodeValue + "'>"
           + result.childNodes[0].nodeValue + "</a>"
           + buffer;
    result=nodes.iterateNext();
}
document.write(buffer);

无需借助 documentFragment 和类似的现代工具;)

于 2012-09-06T23:45:52.340 回答
0

首先更改 XPathResult 的设置。您需要一个有序的快照类型。iterateNext() 不起作用,因为它没有数字键。

var result = document.evaluate(source, xml, null, XPathResult.ORDERED_NODE_SNAPSHOT_TYPE, null);

然后像这样向后循环。

for (var i = result.snapshotLength - 1; i >= 0; i--){
    document.write("<h2>" + result.snapshotItem(i).textContent + "</h2>");
    document.write("<a href='../pics/" + result.snapshotItem(i).textContent + "'>" 
    + result.snapshotItem(i).textContent + "</a>");

}

PS:您的<a>标签代码中缺少“>”。不知道你的目标是什么输出,所以我猜了一下。

于 2012-09-07T00:03:52.327 回答
0

这是一篇文章,展示了一种排序和迭代的方式:

http://blogs.msdn.com/b/kaevans/archive/2006/04/17/577456.aspx

于 2012-09-06T23:47:14.020 回答