如何在javascript中检索数组中的项而不是数组本身?

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (1)
  • 关注 (0)
  • 查看 (37)

我的数据来自用户并存储为对象,该对象需要在服务器端进行一些按摩后进入Mongo。我正在使用Mongoose并使用$push {item}语法将项目插入到我的数据库中。

我的Mongoose模型具有photos: []语法,只是一个简单的数组。在该阵列内部我需要上传的照片。但是如果用户在不同时间上传,我的数组最终会得到一个数组数组,而我只需要一个包含多个对象的简单数组。

这是我的路线:

const testMedia = async (req, res) => {
  //loop through the res.locals.ids and save each as their own photo in the event
  let events = [];
  let photosArray =
  let owner = {id: req.user._id};
  const promises =  await res.locals.ids.map((photoLink) => {
     events.push({link: photoLink.link,
     dateUploaded: new Date(Date.now()).toLocaleString(),
     eventID: req.body.eventId,
     owner: owner
     })
  });
  await Event.findByIdAndUpdate(
      req.body.eventId,
      { $push: {
        photos: events
      }},
      { save: true, upsert: true, new: true },
      (err) => {
        if (err){
          console.log("Error in testMedia  ||  " + err);
          res.sendStatus(300);
        }
      }
    );

  await Promise.all(promises);
  res.render("eventDisplay", { events: event });
  res.end();
};

events遇到的问题是,如果我将项目推入I中,当我只需要对象本身时,我将推送一个对象数组,因此要么每个对象要插入一个数据库调用,这似乎是浪费资源,或者我需要找到一种方法来插入所有对象而不将它们包装在一个数组中。

提问于
用户回答回答于

根据Mongo文档,可以使用 $each

.findByIdAndUpdate(req.body.eventId, {
  $push: {
    photos: { $each: events }
  }
})

这会将多个项目推送到阵列中

扫码关注云+社区

领取腾讯云代金券