jQuery帮助-将XML解析为数组



我目前正在开发一个HTML游戏,用户可以拖动项目并将其放入正确的类别中。类别及其项是在XML文档中定义的。

我的XML格式:

<config>
<game>
    <title>Dementia</title>
        <cat>
            <catTitle>Mild</catTitle>
            <item>mild-1</item>
            <item>mild-2</item>
            <item>mild-3</item>
        </cat>
        <cat>
            <catTitle>Moderate</catTitle>
            <item>Moderate-1</item>
            <item>Moderate-2</item>
            <item>Moderate-3</item>
        </cat>
        <cat>
            <catTitle>Severe</catTitle>
            <item>Severe-1</item>
            <item>Severe-2</item>
        </cat>
</game>

我想使用jQuery将这个XML文件解析为基于其类别的单独数组。

例如:

array1=[密耳-1、密耳-2、密耳-3]

array2=[适度-1、适度-2、适度-3]等…

这将允许我根据类别数组检查删除的项的属性是否正确。

如果你对如何做到这一点有任何其他想法,请提出建议。

提前谢谢。

试试,类似这样的东西:

$(document).ready(function() {
    var arr = [];
    $(xml).find("cat").each(function(idx, v) {
        arr[idx] = [];
        $(v).find("item").each(function( i , vi) {
            arr[idx].push( $(vi).text() );
        });             
    });
    console.log( arr );
});

将返回类似的响应

[
    ["mild-1", "mild-2", "mild-3"]
, 
    ["Moderate-1", "Moderate-2", "Moderate-3"]
, 
    ["Severe-1", "Severe-2"]
]

因此,您可以访问单个阵列作为,

console.log( arr[0] ); //for first, and so on..

这样尝试:

$("cat", xml).each(function () {
   $("item", this).toArray();
});
$($.parseXML(xml)).find("cat").each(function (idx, v) {
  arr[idx] = [];
  $(v).find("item").each(function (i, vi) {
     arr[idx].push($(vi).text()
  );
 });

因为CCD_ 1在IE中不起作用(请参阅此CCD_ 2在IE中不会返回数据,但在Firefox和Chrome中会返回数据)。

最新更新