<分区>
在我的数据库中我有这样的东西:
"_id" : ObjectId("5c0d9d54df58cb2fdc7f735a"),
"notificationMessages" : [
{
"message" : "Some message 1",
"showNotification" : true,
"projectId" : "5c0e40683500fe72a8e3ce8f"
},
{
"message" : "Some message 2",
"showNotification" : true,
"projectId" : "5c0e6e113500fe72a8e3ce90"
}
],
当我在客户端点击具体消息时,我想将“showNotification”更新为 false。为此,我将我从客户端单击的数组的索引发送到 nodejs 服务器,我试图将该结果用作我的更新查询的索引,但它不起作用。首先我尝试这样做:
exports.delete_notification = async function(req,res) {
let arrayIndex = req.body.index;
console.log("This is the arrayIndex")
console.log(arrayIndex)
await User.update(
{_id: req.session.userId},
{$set: {'notificationMessages.' + arrayIndex + '.showNotification': false }}
)
res.status(200).json("done")
但是,更新查询中似乎不允许使用加号: (忽略 console.log(theString),我知道 theString 不存在,但这不是问题所在。)
所以我尝试做这个查询
await User.update(
{_id: req.session.userId},
{$set: {'notificationMessages.arrayIndex.showNotification': false }}
)
然而,这会导致以下错误:
(node:20656) UnhandledPromiseRejectionWarning: Unhandled promise rejection (rejection id: 1): MongoError: Cannot create field 'arrayIndex' in element {notificationMessages: [ { message: (....)
任何人都可以帮助我如何正确更新从客户端收到的索引?