如何在JavaScript中检索数组内部而不是数组本身的项目

时间:2018-10-06 15:07:36

标签: javascript arrays mongodb mongoose javascript-objects

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

我的猫鼬模型的语法为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中,那么当我只需要对象本身时,我将推入一个对象数组,因此我要么必须为每个对象进行一个数据库调用插入,这似乎浪费资源,或者我需要找到一种方法来插入所有对象而不将它们包装在数组中。

由于某种原因,我无法弄清楚。有任何想法吗?

1 个答案:

答案 0 :(得分:1)

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

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

这会将多个项目推入您的数组。