繁体   English   中英

将此XML转换为JSON Jquery

[英]Turning this XML into JSON Jquery

所以我有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数组? 我真的可以使用一些建议。

谢谢大家的帮助。

我只是回答了我自己的问题,我想...

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

var myarray = {};

myarray[key1] = val1;

因此,这里是xml: http//honciano.com/kayokee/ci/uploads/xmlbackup2.xml

这是我用来创建Json Array的代码。 我不知道这是否是正确的方法,但是我知道了它能起作用。 我遇到的问题是从“ 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);
                        });
                    });


                }
            })

它完全可以正常工作,并且给了我我想要的东西。 谢谢大家!

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM