繁体   English   中英

如何添加属性到嵌套的javascript数组(对象)?

[英]How to add property to nested javascript array (of objects)?

我正在尝试向javascript嵌套数组对象添加属性...

我需要遍历树以获取text属性的值并将其转换为小写并将此数据添加为新属性(lowerText)

旧数组:

 var oldObject= [{
        text: "Subgroup3",
        items: [{
            text: "subgroup5",
            items: [{
                text: "subgroup6",
                items: [{
                    text: "subgroup7",
                    items: [{
                        text: "subgroup8"
                    }]
                }]
            }]
        }]
    }]

我需要如下的新数组对象:

   var newObject= [{
        text: "Subgroup3",
        lowerText:"subgroup3",
        items: [{
            text: "subgroup5",
            lowerText:"subgroup5",
            items: [{
                text: "subgroup6",
                lowerText:"subgroup6",
                items: [{
                    text: "subgroup7",
                    lowerText:"subgroup7",
                    items: [{
                        text: "subgroup8",
                        lowerText:"subgroup8",
                    }]
                }]
            }]
        }]
    }]

这是我尝试过的方法,它遍历每个对象并将项目(数组)传递给递归函数以设置属性,但它似乎无法正常工作。 不知道我在做什么错,有人可以帮我提供这个代码吗?

for (var i = 0; i < data.length; i++) {
                    data[i].lowerText=data[i].text.toLowerCase();
                    loopTree(data[i].items);
                }

function loopTree(node){
 if (node) {
        $.each(node, function (idx, item) {
            item.lowerText=item.text.toLowerCase();
            if(item.items){
                loopTree(item.items)
            }
        });
    }
    }

编辑:下面的代码完成了这项工作。

  for (var i = 0; i < data.length; i++) {
                    if(data[i]){
                        process( data[i]);
                    }
                }

function process(val) {
    val.lowerText = val.text.toLowerCase();  
    if(val.items){
        for(var i = 0, len = val.items.length; i < len; i++) {
            process(val.items[i]);
        }
    }
}

如果您不想克隆对象而只修改现有对象,请尝试以下操作:

function process(val) {
   val.lowerText = val.text.toLowerCase();

   for(var i = 0, len = val.items.length; i < len; i++) {
       process(val.items[i]);
   }
}

process(obj);

如果要将值保留在旧数组中,只需将新对象推入旧数组即可:

oldObject.push(newObject[0]);

如果您只需要替换整个阵列,那么琐碎的操作,

oldObject = newObject;

暂无
暂无

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

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