请帮助我重新创建从API接收到的JSON对象,请参阅下面的JSON对象( API )是输入JSON
{
'Demo-1': [
{
sku: 'Brisk',
count: '2',
},
{
sku: 'Pepsi Cans',
count: '2',
},
{
sku: 'Pepsi Cans',
count: '4',
}
],
'Demo-2' : [
{
sku: 'Mountain',
count: '4',
},
{
sku: 'Pepsi Bottles',
count: '4',
},
{
sku: 'Lipton Dietgreentea',
count: '2',
},
{
sku: 'Lipton Dietgreentea Mixedberry',
count: '2',
}
]
}在JSON对象下面使用附加键进行转换,并重新构造另一个键内的数组项
结果应该类似于
{
'Demo-1': {
items: [{
sku: 'Brisk',
count: '2',
},
{
sku: 'Pepsi',
count: '2',
},
{
sku: 'Pepsi',
count: '4',
}
],
mode: "Veri",
status: "open"
},
'Demo-2': {
"items": [{
sku: 'Mountain',
count: '4',
},
{
sku: 'Pepsi Bottles',
count: '4',
},
{
sku: 'Lipton Dietgreentea',
count: '2',
},
{
sku: 'Lipton Dietgreentea Mixedberry',
count: '2',
}
],
mode: "Clear",
status: "Closed"
}
}我尝试了角度,但我无法达到这个结果,请看下面的代码
Object.entries(_data).map((items,idx)=>{
this._newPickLists = {
items[0] :{
items : items[1],
mode : 'Verification',
status : 'open'
}
}
})提前谢谢
发布于 2021-10-08 06:36:59
使用Object.entries和Object.fromEntries,您可以将值更改为以项作为键的对象。
const obj = {"Demo-1":[{"sku":"Brisk","count":"2"},{"sku":"Pepsi Cans","count":"2"},{"sku":"Pepsi Cans","count":"4"}],"Demo-2":[{"sku":"Mountain","count":"4"},{"sku":"Pepsi Bottles","count":"4"},{"sku":"Lipton Dietgreentea","count":"2"},{"sku":"Lipton Dietgreentea Mixedberry","count":"2"}]};
console.log(
Object.fromEntries(
Object.entries(obj).map(
([key, items]) => [key, { items, mode: "verification", status: "open" }]
)
)
)
发布于 2021-10-08 06:38:44
只需将newObject替换为应用程序中的变量。
const newObject = {};
for (const [key, value] of Object.entries(obj)) {
newObject[key] = {};
newObject[key]["items"] = value;
newObject[key].mode = "Clear";
newObject[key].status = "Closed";
}
console.log(newObject);发布于 2021-10-08 06:43:00
下面是更新原始数据对象的解决方案:
Object.keys(data).forEach((key)=> {
data[key] = {items: data[key], mode: 'Veri', status: 'open' }}
)https://stackoverflow.com/questions/69491395
复制相似问题