[英]How to remove parent fields in json variable and convert it to json in javascript or jquery
我正在开展一些涉及很多对象的项目。 我在javascript或jQuery中有以下要求。
我有以下对象:
var dataset = {
"d0": { "id": 0, "name": "Housing", "value": 18 },
"d1": { "id": 1, "name": "Travel", "value": 31.08 },
"d2": { "id": 2, "name": "Restaurant", "value": 64 },
"d3": { "id": 3, "name": "Bank", "value": 3 },
"d4": { "id": 4, "name": "Movies", "value": 10 }
};
如何删除父字段并将其作为对象如下所示?
var d= [
{ "id": 0, "name": "Housing", "value": 18 },
{ "id": 1, "name": "Travel", "value": 31.08 },
{ "id": 2, "name": "Restaurant", "value": 64 },
{ "id": 3, "name": "Bank", "value": 3 },
{ "id": 4, "name": "Movies", "value": 10 }
]
执行此操作后,我想将此对象传递给javascript函数,该函数操纵此变量d的值。
if(value >= 10 && value <= 20) {
d[index].value = 7;
}
if(value >= 20 && value <= 40) {
d[index].value = 8;
}
更新的对象应如下所示:
var d= [
{ "id": 0, "name": "Housing", "value": 7 },
{ "id": 1, "name": "Travel", "value": 8 },
{ "id": 2, "name": "Restaurant", "value": 64 },
{ "id": 3, "name": "Bank", "value": 3 },
{ "id": 4, "name": "Movies", "value": 10 }
]
我尝试使用for循环循环到数据集,但无法实现我的要求。
有帮助吗?
只需使用Array.prototype.map方法映射它:
var dataset = { "d0": { "id": 0, "name": "Housing", "value": 18 }, "d1": { "id": 1, "name": "Travel", "value": 31.08 }, "d2": { "id": 2, "name": "Restaurant", "value": 64 }, "d3": { "id": 3, "name": "Bank", "value": 3 }, "d4": { "id": 4, "name": "Movies", "value": 10 } }; var d = Object.keys(dataset).map(function(key) { var obj = dataset[key]; if (obj.value >= 10 && obj.value <= 20) { obj.value = 7; } else if (obj.value >= 20 && obj.value <= 40) { obj.value = 8; } return obj; }); document.write('<pre>' + JSON.stringify(d, null, 4) + '</pre>');
使用Array#forEach
和Object.keys()
迭代对象。
var dataset = { "d0": { "id": 0, "name": "Housing", "value": 18 }, "d1": { "id": 1, "name": "Travel", "value": 31.08 }, "d2": { "id": 2, "name": "Restaurant", "value": 64 }, "d3": { "id": 3, "name": "Bank", "value": 3 }, "d4": { "id": 4, "name": "Movies", "value": 10 } }; // Declare resulting empty array var d = []; // Get object keys and iterate over them Object.keys(dataset).forEach(function (key) { // Get the value from the object var value = dataset[key].value; // Update values if in the range if(value >= 10 && value <= 20) { dataset[key].value = 7; } else if(value > 20 && value <= 40) { dataset[key].value = 8; } // Push the updated(or not) value in the array d.push(dataset[key]); }); console.log(d); document.getElementById('result').innerHTML = JSON.stringify(d, null, 4);
<pre id="result"></pre>
你可以这样做:
var dataset = {
"d0": { "id": 0, "name": "Housing", "value": 18 },
"d1": { "id": 1, "name": "Travel", "value": 31.08 },
"d2": { "id": 2, "name": "Restaurant", "value": 64 },
"d3": { "id": 3, "name": "Bank", "value": 3 },
"d4": { "id": 4, "name": "Movies", "value": 10 }
};
首先删除字符串键:
var d = [];
for(var k in dataset){
d.push(dataset[k]);
}
然后迭代生成的数组,相应地修改它:
for(var k in d){
var value = d[k]['value'];
if(value>=10 && value<=20){
d[k].value=7;
}
if(value>=20 && value<=40){
d[k].value=8;
}
}
这给出了你正在寻找的结果:
var dataset = {
"d0": { "id": 0, "name": "Housing", "value": 18 },
"d1": { "id": 1, "name": "Travel", "value": 31.08 },
"d2": { "id": 2, "name": "Restaurant", "value": 64 },
"d3": { "id": 3, "name": "Bank", "value": 3 },
"d4": { "id": 4, "name": "Movies", "value": 10 }
};
var d = Object.keys(dataset).map(function(key) {
var v = dataset[key].value;
if (v >= 10 && v <= 20) dataset[key].value = 7;
else if (v > 20 && v <= 40) dataset[key].value = 8;
return dataset[key];
});
试试这个,
function datasetToArrOfObj(dataset){
var rslt = [];
for (var key in dataset) {
if (dataset.hasOwnProperty(key)) {
rslt.push(dataset[key]);
}
}
return rslt;
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.