我试图将新属性附加到一些 JSON 对象,但根本没有。我怎样才能做到这一点?
例如,这是我的 JSON 数组:
var eventsArray;
eventsArray = [
{
"title" : "Marco 1",
"user": "Marco",
"start" : "2016-01-12T16:00:00-05:00",
"end" : "2016-01-12T17:00:00-05:00"
}, {
"title" : "Marco 2",
"user": "Marco",
"start" : "2016-01-12T10:00:00-05:00",
"end" : "2016-01-12T12:00:00-05:00"
}, {
"title" : "Marta 1",
"user": "Marta",
"start" : "2016-01-12T09:00:00-05:00",
"end" : "2016-01-12T10:00:00-05:00"
}, {
"title" : "Marta 2",
"user": "Marta",
"start" : "2016-01-13T09:00:00-05:00",
"end" : "2016-01-13T10:00:00-05:00"
}, {
"title" : "Veronica 1",
"user": "Veronica",
"start" : "2016-01-12T13:00:00-05:00",
"end" : "2016-01-12T14:00:00-05:00"
}, {
"title" : "Veronica 2",
"user": "Marco",
"start" : "2016-01-11T13:00:00-05:00",
"end" : "2016-01-11T14:00:00-05:00"
}
];
然后我需要向用户 Veronica 添加一个新属性,例如 "color": "red",即:
var eventsArray;
eventsArray = [
{
"title" : "Marco event 1",
"user": "Marco",
"start" : "2016-01-12T16:00:00-05:00",
"end" : "2016-01-12T17:00:00-05:00"
}, {
"title" : "Marco event 2",
"user": "Marco",
"start" : "2016-01-12T10:00:00-05:00",
"end" : "2016-01-12T12:00:00-05:00"
}, {
"title" : "Marta event 1",
"user": "Marta",
"start" : "2016-01-12T09:00:00-05:00",
"end" : "2016-01-12T10:00:00-05:00"
}, {
"title" : "Marta event 2",
"user": "Marta",
"start" : "2016-01-13T09:00:00-05:00",
"end" : "2016-01-13T10:00:00-05:00"
}, {
"title" : "Veronica event 1",
"user": "Veronica",
"start" : "2016-01-12T13:00:00-05:00",
"end" : "2016-01-12T14:00:00-05:00",
"color" : "red"
}, {
"title" : "Veronica event 2",
"user": "Veronica",
"start" : "2016-01-11T13:00:00-05:00",
"end" : "2016-01-11T14:00:00-05:00",
"color" : "red"
}
];
上面我刚刚(手动)添加了“颜色”:“红色”,仅添加到具有“user”===“Veronica”(后两个)的对象。我如何通过 JavaScript 做到这一点?
我尝试了一些方法但没有成功,例如:
eventsArray[4].color = "red";
eventsArray[5].color = "red";
或者:
eventsArray.user["Veronica"].color = "red";
eventsArray.user["Veronica"].color = "red";
来 self 学习使用 JSON 的几天。
请注意,在这种特定情况下,具有不同属性的对象不会出现任何问题:我的程序不会爆炸! :P
谢谢。
最佳答案
有很多方法可以做到这一点。
这是一种简单的方法:
eventsArray.forEach( function( event ) {
if( event.user == 'Veronica' ) event.color = 'red';
});
当然,您可能希望对其他用户和颜色执行此操作。因此最好将其概括为一个函数:
function setUserColor( events, user, color ) {
events.forEach( function( event ) {
if( event.user == user ) event.color = color;
});
}
然后你可以这样调用它:
setUserColor( eventsArray, 'Veronica', 'red' );
现在您也可以为其他用户执行相同的操作:
setUserColor( eventsArray, 'Marta', 'green' );
关于javascript - 如何向 JSON 数组添加新属性?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36278836/