やりたいこと
findOneAndUpdate
後の情報を配列[]
にjson
で格納された状態で貰いたい。
現状
例えば、['旅行','おでかけ','デート']
という配列を
increaseQuantity()
の引数に渡しても、
console.log
では[null,null,null]
になってしまう。
const updateTaggedQuantity = async() => { let promiseArr = []; ['旅行','おでかけ','デート'].forEach(tagName => promiseArr.push(increaseQuantity(tagName))); Promise.all(promiseArr) .then(res => console.log(res)) .catch(err => console.log(err)) } const increaseQuantity = async (tagNames) => { console.log('開始'); const updates = tagNames.map((tagname) => { return Tag.findOneAndUpdate({ name: tagname }, { $inc: { taggedQuantity: 1 } }, { new: true }); }); await Promise.all(updates).then(function (values) { console.log(values); // [ null, null, null ] }); console.log('終了'); // こうしたいのですが... 現状難しい... // 1つ1つのJSONはfindOneAndUpdateの返り値であってほしいです return JSONの入った配列 };
おそらく
Promise
の挙動がキーな気がしているのですが、自身にはまだ難しく、ご助力いただけると幸いです。よろしくお願いします。