![](/img/trans.png)
[英]How to add property to array of objects if not found in 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.