这条线是干什么的?(javascript中的xml2json转换)
嗨,我在网上找到了一种将XML转换为JSON的方法。我已经用了一段时间,效果很好。现在我需要修改它以满足我的特定需求,但是修改它很困难,因为我不完全理解这种方法每行都在做什么。具体如下这条线是干什么的?(javascript中的xml2json转换),javascript,json,xml,dom,nodelist,Javascript,Json,Xml,Dom,Nodelist,嗨,我在网上找到了一种将XML转换为JSON的方法。我已经用了一段时间,效果很好。现在我需要修改它以满足我的特定需求,但是修改它很困难,因为我不完全理解这种方法每行都在做什么。具体如下 if (typeof(obj[nodeName].push) == "undefined" ) 我不懂。我相信这个操作是在一个节点列表上完成的,它只有一个方法,而不是它 如果有帮助的话,这里是整个方法 function xmlToJsonHelper(xml) { // Create the return
if (typeof(obj[nodeName].push) == "undefined" )
我不懂。我相信这个操作是在一个节点列表上完成的,它只有一个方法,而不是它
如果有帮助的话,这里是整个方法
function xmlToJsonHelper(xml) {
// Create the return object
var obj = {};
console.log(typeof(xml))
if (xml.nodeType == 1) { // element
// do attributes
if (xml.attributes.length > 0) {
obj["@attributes"] = {};
for (var j = 0; j < xml.attributes.length; j++) {
var attribute = xml.attributes.item(j);
obj["@attributes"][attribute.nodeName] = attribute.nodeValue;
}
}
} else if (xml.nodeType == 3 ) { // text
obj = xml.nodeValue;
}
// do children
if (xml.hasChildNodes()) {
for(var i = 0; i < xml.childNodes.length; i++) {
var item = xml.childNodes.item(i);
var nodeName = item.nodeName;
if (typeof(obj[nodeName]) == "undefined" ) {
if(xml.childNodes[i].nodeType != 3 || !xml.childNodes[i].data.match("\\n"))
obj[nodeName] = xmlToJsonHelper(item); //modded to call helper
}
else {
if (typeof(obj[nodeName].push) == "undefined" ) {
var old = obj[nodeName];
obj[nodeName] = [];
obj[nodeName].push(old);
}
obj[nodeName].push(xmlToJsonHelper(item));//modded to call helper
}
}
}
return obj;
函数xmlToJsonHelper(xml){
//创建返回对象
var obj={};
log(typeof(xml))
如果(xml.nodeType==1){//元素
//做属性
如果(xml.attributes.length>0){
obj[“@attributes”]={};
for(var j=0;j
}) 它似乎在测试obj对象中的元素是否为数组 通过快速查看您提供的代码,该方法似乎遍历了xml中的元素,并尝试使用相同的节点嵌套构建JSON对象(obj)。大概是
<ants>
<hill></hill>
<picnic></picnic>
</ants>
对obj[nodeName].push的测试只要求obj[nodeName]中的元素具有push函数,这意味着它是一个数组。如果不是,则它会取出该值,使新值成为空数组,然后将旧值推送到数组中
{
ants: [
{hill:...},
{picnic:...}
]
}