首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >对象数组内部连接对象数组

对象数组内部连接对象数组
EN

Stack Overflow用户
提问于 2021-04-05 10:32:26
回答 3查看 59关注 0票数 0

假设我有一个对象数组,如:

代码语言:javascript
复制
const bookDetails = [
    {
        "bookId": "1235",
        "emailId": "samplek@gmail.com",
        "bookIssue": [{"Book not properly aligned": true, "some issue1": true}]
    },
    {
        "bookId": "1235",
        "emailId": "s@gmampleail.com",
        "bookIssue": [{"some issues with book": true, "some issue2": true}]
    }]

我要交单的内容如下:

代码语言:javascript
复制
[
    {"bookId": "1235", "emailId": "samplek@gmail.com", "bookIssue": "Book not properly aligned,some issue1"},
    {"bookId": "1235", "emailId": "s@gmampleail.com", "bookIssue": "some issues with book,some issue2"}
]

为此我试过,

代码语言:javascript
复制
bookDetails.map((i) => i.bookIssue = Object.keys(i.bookIssue[0]).join(","))

它根据需要给出O/p,但它开始给出价值,

代码语言:javascript
复制
[{"bookId":"1235","emailId":"samplek@gmail.com","bookIssue":"0"},
{"bookId":"1235","emailId":"s@gmampleail.com","bookIssue":"0"}]

有什么可以解决的问题,还有什么其他的方法可以实现吗?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2021-04-05 10:37:48

请参阅my comment和georg,您的代码工作正常(除了不正确地使用map ),前提是您想要修改适当的对象。

如果您想要在一个新数组中创建新对象(例如,正确使用map ),您可以做您要做的事情来获取键,但是创建一个新对象,结果如下:

代码语言:javascript
复制
const result = bookDetails.map(entry => {
    // Grab the keys from the first entry and join them
    const bookIssue = Object.keys(entry.bookIssue[0]).join(",");
    // Build the new object to return
    return {...entry, bookIssue};
});

活生生的例子:

代码语言:javascript
复制
const bookDetails = [
    {"bookId":"1235","emailId":"samplek@gmail.com","bookIssue":[{"Book not properly aligned": true,"some issue1":true}]},
    {"bookId":"1235","emailId":"s@gmampleail.com","bookIssue":[{"some issues with book": true, "some issue2":true }]}
];

const result = bookDetails.map(entry => {
    // Grab the keys from the first entry and join them
    const bookIssue = Object.keys(entry.bookIssue[0]).join(",");
    // Build the return object
    return {...entry, bookIssue};
});

console.log(result);

如果bookIssue可以有多个条目(如果不能,为什么它是一个数组?)您希望将的bookIssue中的所有条目连接在一起,您可以使用bookIssue上的map从其对象中获取所有键并将它们连接起来,然后加入结果数组:

代码语言:javascript
复制
const result = bookDetails.map(entry => {
    const bookIssue = entry.bookIssue
        .map(entry => Object.keys(entry).join(","))
        .join(",");
    // Build the return object
    return {...entry, bookIssue};
});

活生生的例子:

代码语言:javascript
复制
const bookDetails = [
    {"bookId":"1235","emailId":"samplek@gmail.com","bookIssue":[
        {"Book not properly aligned": true,"some issue1":true},
        {"another issue": true,"yet another issue":true}
    ]},
    {"bookId":"1235","emailId":"s@gmampleail.com","bookIssue":[{"some issues with book": true, "some issue2":true }]}
];

const result = bookDetails.map(entry => {
    const bookIssue = entry.bookIssue
        .map(entry => Object.keys(entry).join(","))
        .join(",");
    // Build the return object
    return {...entry, bookIssue};
});

console.log(result);

当然,如果只有一个条目,这也是可行的。

票数 1
EN

Stack Overflow用户

发布于 2021-04-05 10:53:46

您的代码也能工作,因为您正在更改对象bookIssue (与bookDetails中的引用相同)。下面是将属性bookIssue映射到所需值的另一种方法,方法是在映射中返回新对象。

代码语言:javascript
复制
const bookDetails = [
    {
        "bookId": "1235",
        "emailId": "samplek@gmail.com",
        "bookIssue": [{"Book not properly aligned": true, "some issue1": true}]
    },
    {
        "bookId": "1235",
        "emailId": "s@gmampleail.com",
        "bookIssue": [{"some issues with book": true, "some issue2": true}]
    }];
    
const output = bookDetails.map(book => {
  return {...book, bookIssue: Object.keys(book.bookIssue[0]).join(',')}
});

console.log(output);

票数 1
EN

Stack Overflow用户

发布于 2021-04-05 11:03:48

只需使用forEach更新您的Map函数,并查看console.log(bookDetails)。您正在检查地图输出,而不是检查bookDetails。这就是你困惑的原因。也可以在代码中检查console.log(bookDetails)。它将如预期的那样工作:bookDetails.forEach((i) => i.bookIssue = Object.keys(i.bookIssue).join(",“);

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66951615

复制
相关文章

相似问题

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