[英]How to modify JSON array?
如何在以下多維JSON數組中的特定索引處更新值?
我想更新放置在footer_logo
節點內的background-image
的值。
{
"Machine1": {
"sidebar_inner": {
"img": "img/pill.png",
"background-color": "#ffffff",
"side_logo": {
"background-image": "../footer_logo.png"
}
},
"lb_footer": {
"img": "img/bin.png",
"footer_logo": {
"background-image": "..img/footer_logo.png"
}
},
"machine_stand": {
"img": "img/machine_stand.png"
},
"side": {
"backgroundcolor": "#ccc"
}
}
}
我在這里添加了一個jsfiddle示例。 非常簡單,請看下面的代碼。
var myJson = {
"Machine1": {
"sidebar_inner": {
"img": "img/pill.png",
"background-color": "#ffffff",
"side_logo": {
"background-image": "../footer_logo.png"
}
},
"lb_footer": {
"img": "img/bin.png",
"footer_logo": {
"background-image": "..img/footer_logo.png"
}
},
"machine_stand": {
"img": "img/machine_stand.png"
},
"side": {
"backgroundcolor": "#ccc"
}
}
};
myJson.Machine1.lb_footer.footer_logo['background-image'] = 'New value.';
alert(myJson.Machine1.lb_footer.footer_logo['background-image']);
要更新嵌套值,可以將鍵(索引用於數組)鏈接在一起以找到合適的值。
這是代碼,其格式易於使用:
var obj = {"Machine1": {
"sidebar_inner": {
"img": "img/pill.png",
"background-color": "#ffffff",
"side_logo": {
"background-image": "../footer_logo.png"
}
},
"lb_footer": {
"img": "img/bin.png",
"footer_logo": {
"background-image": "..img/footer_logo.png"
}
},
"machine_stand": {
"img": "img/machine_stand.png"
},
"side": {
"backgroundcolor":"#ccc"
}
}}
更新“ footer_logo”的背景圖片: obj.Machine1.lb_footer,footer_logo.background-image = "something new";
更新“ machine_stand's” img:
obj.machine_stand.img = "new/link.jpg";
// or use 'bracket notation', it's the same thing
obj['machine_stand']['img'] = "new/link.jpg"
嘗試這個。 一個工作的jsfiddle
var json= '{"Machine1":{"sidebar_inner":{"img":"img\/pill.png","background-color":"#ffffff","side_logo":{"background-image":"..\/footer_logo.png"}},"lb_footer":{"img":"img\/bin.png","footer_logo":{"background-image":"..img\/footer_logo.png"}},"machine_stand":{"img":"img\/machine_stand.png"},"side":{"backgroundcolor":"#ccc"}}}';
var jsonObj = JSON.parse(json);
jsonObj.Machine1.lb_footer.footer_logo['background-image'] = 'abc';
arr["Machine1"]["lb_footer"]["footer_logo"]["background-image"] = mynewvalue;
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.