首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何用新的键值重构JSON对象?

如何用新的键值重构JSON对象?
EN

Stack Overflow用户
提问于 2021-10-08 06:24:29
回答 3查看 71关注 0票数 0

请帮助我重新创建从API接收到的JSON对象,请参阅下面的JSON对象( API )是输入JSON

代码语言:javascript
复制
{
  '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对象下面使用附加键进行转换,并重新构造另一个键内的数组项

结果应该类似于

代码语言:javascript
复制
{
    '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"
    }
}

我尝试了角度,但我无法达到这个结果,请看下面的代码

代码语言:javascript
复制
 Object.entries(_data).map((items,idx)=>{
     
      this._newPickLists = {
        items[0] :{
          items : items[1],
          mode : 'Verification',
          status : 'open'
        }
      }

    
    })

提前谢谢

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2021-10-08 06:36:59

使用Object.entriesObject.fromEntries,您可以将值更改为以项作为键的对象。

代码语言:javascript
复制
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" }]
    )
  )
)

票数 1
EN

Stack Overflow用户

发布于 2021-10-08 06:38:44

只需将newObject替换为应用程序中的变量。

代码语言:javascript
复制
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);
票数 1
EN

Stack Overflow用户

发布于 2021-10-08 06:43:00

下面是更新原始数据对象的解决方案:

代码语言:javascript
复制
  Object.keys(data).forEach((key)=> { 
     data[key] = {items: data[key], mode: 'Veri', status: 'open' }}
  )
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/69491395

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档