使用getElementsByTagName排序

时间:2013-06-18 12:27:08

标签: javascript xml

我想解析一个xml文件,并按照与xml中显示的顺序不同的顺序列出元素。每个子元素都有一个名称和一个数字值,我想列出名称,但按数字值的顺序。 xml文件看起来类似于:

 <stories>
    <story>
      <name>fast</name>
      <number>1000</number>
    </story>
    <story>
      <name>bomb</name>
      <number>2</number>
    </story>
    <story>
      <name>descend</name>
      <number>500</number>
    </story>
    <story>
      <name>A</name>
      <number>1</number>
    </story>
    <story>
      <name>can</name>
      <number>40</number>
    </story>
    <story>
      <name>extremely</name>
      <number>10000</number>
    </story>
 </stories>

更新: 我的脚本看起来像这样atm:

<script type="text/javascript">
var xmlhttp = new XMLHttpRequest(); // code for IE7+, Firefox, Chrome, Opera, Safari
testOpen = xmlhttp;
testOpen.open("GET", "test.xml", false);
xmlhttp.send();
testDoc = testOpen.responseXML;
stories = testDoc.getElementsByTagName("story");
function display(){
    var arrayStory = Array.prototype.slice.call(stories, 0);
    arrayStory.sort(function(a, b){
        return a.getElementsByTagName("number")[0].firstChild.nodeValue - b.getElementsByTagName("number")[0].firstChild.nodeValue;
    });
    document.getElementById("show").innerHTML = arrayStory.map(function(story){
        return story.getElementsByTagName("name")[0].firstChild.nodeValue;
    }).join("<br>");
};
</script>

我的listorder以这种方式工作。我的问题是,如何列出名称旁边的数字(或任何其他节点值)(不使用表格)以及如何在列表中设置条件/创建子列表(如果我不能,请帮我创建)我可以的清单),非常感谢您的帮助!提前谢谢!

2 个答案:

答案 0 :(得分:0)

这个display代码应该这样做:

var arr = [],
    l = stories.length;
for (var i=0; i<l; i++)
    arr.push( {
        story: stories[i],
        number: parseInt(stories[i]
                           .getElementsByTagName("number")[0]
                           .firstChild.nodeValue, 10)
        // seriosly, an attribute on the <story> element is more appropriate
    } );
arr.sort(function(a, b) {
    return a.number - b.number;
});
document.getElementById("show").innerHTML = arr.map(function(o) {
    return o.story.getElementsByTagName("name")[0].firstChild.nodeValue;
}).join("<br />");

答案 1 :(得分:-2)

我建议你使用Json而不是XML。

然后你可以使用javascript sort()方法使用你在这里找到的答案对JSON进行排序:Sort array of objects by single key with date value

相关问题