将此XML转换为JSON Jquery

时间:2013-04-05 22:37:06

标签: jquery xml arrays json loops

所以我从Winamp获得了这个XML

<dict>
        <key>Track ID</key><integer>0</integer>
        <key>Name</key><string>American Idol 2013</string>
        <key>Artist</key><string>Amber Holcomb</string>
        <key>Album Artist</key><string>Amber Holcomb</string>
        <key>Album</key><string>Unknown Album</string>
        <key>Kind</key><string>MPEG audio file</string>
        <key>Size</key><integer>3645</integer>
        <key>Total Time</key><integer>233000</integer>
        <key>Date Modified</key><date>Thu Mar 14 12:11:12 2013</date>
        <key>Date Added</key><date>Thu Apr 04 16:10:15 2013</date>
        <key>Bitrate</key><integer>128</integer>
        <key>Location</key><string>file://localhost/Z:%5Canthony%5CMusic%5CiTunes%5CiTunes%20Media%5CMusic%5CUnknown%20Artist%5CUnknown%20Album%5CAmber%20Holcomb%20-%20A%20Moment%20Like%20This%20-%20Studio%20Version%20-%20American%20Idol%202013.mp3</string>
        <key>File Folder Count</key><integer>-1</integer>
        <key>Library Folder Count</key><integer>-1</integer>
      </dict>

我想把它变成JsonArray

var myarray = {"TrackID":0, "Name":"American IDol 2013"...};

我发现了如何循环遍历每个标签,但我似乎无法解决这个问题。我正在考虑创建一个预定义的Json数组或{"TrackID": "", "Name":""},当JSON完成时,我将它推入主JSON(如果我没有正确解释,那就很抱歉)。

有没有办法用其余的方法创建所有键的单个数组,然后将它们合并到JSON数组中?我可以真的使用一些建议。

谢谢大家的帮助。

1 个答案:

答案 0 :(得分:1)

我刚才回答了我自己的问题......

var key1 = "keyname";
var val1 = "value";

var myarray = {};

myarray[key1] = val1;

所以这是xml:http://honciano.com/kayokee/ci/uploads/xmlbackup2.xml

这是我用来创建Json数组的代码。我不知道这是否是正确的做法,但我得到了它的工作。我遇到的问题是从“KEY”标记获取值并获取“KEY”标记之后的值,但不是“KEY”的标记是“STRING”或“INTEGER”。

所以这就是我创造的......

$.ajax({
                url: "<? echo base_url().'uploads/songlist.xml';?>",
                dataType: 'HTML',

                success: function(data){
                    var myarray ={"track":[]};
                    var key1 = "";
                    var val1 = "";          
                    var arrayContainer = {};
                    var myCount = 0;
                    $(data).find("dict").children("dict").children("dict").each(function(){



                        $(this).children().each(function(i, e){
                            var nodeKey=(this).nodeName;

                            if(nodeKey=="KEY"){
                                key1 = $(this).text();

                            } else {
                                val1 = $(this).text();
                                arrayContainer[key1] = val1;
                                myCount++;
                                //console.log("key1:"+key1+" - val1:"+val1+" - myCount:"+myCount);
                            }               

                            if(myCount==14){
                                myarray.track.push(arrayContainer);
                                arrayContainer={};
                                myCount=0;
                                //console.log("cutoff new line");
                            }           
                        });


                    });

                    $.each(myarray.track, function(i, obj){
                        $.each(obj, function(e, val){
                            console.log("e:"+e+" - val:"+val);
                        });
                    });


                }
            })

它完全有效,它给了我我想要的东西。谢谢大家!