问题可能出在初始数据类型上。如果你使用的是mongoose模型,则需要使用$pull操作符,并且在前端发送axios请求时指定正确的URL和请求类型。下面是一个使用mongoose模型和axios库的示例代码:
前端代码:
axios.delete(`/api/deleteItem/${itemId}`)
.then((response) => {
console.log(response.data)
})
后端代码:
app.delete('/api/deleteItem/:id', (req, res) => {
const id = req.params.id;
Model.findByIdAndDelete(id, (err, result) => {
if (err) throw err;
console.log(result);
res.status(200).send('deleted');
})
})
在这个示例中,我们将MongoDB模型命名为“Model”,并在后端使用findByIdAndDelete方法来查找并删除数据库中匹配的项。 在前端,我们构建了一个HTTP DELETE请求,并在URL中包含传递的参数“itemId”(它可以是你想删除的任何项的ID)。
注意,如果你希望从数组中删除元素,则需要在mongoose模式中设置正确的类型,例如:
const TodoSchema = new Schema({
name: String,
list: [String]
});
在这个示例中,列表项的类型为“String”,所以我们可以在后端route中使用$pull和{ $in: [itemIds] }操作符来删除匹配的项目:
app.delete('/api/deleteItems', (req, res) => {
const itemIds = req.body.ids;
Model.update({}, { $pull: { list: { $in: [...itemIds] } } }, { multi: true }, (err, result) => {
if (err) throw err;
console.log(result);
res.status(200).send('deleted');
})
})
在这个示例中,我们使用update方法来更新数据库,将$pull操作符应用于“list”字段,其中$in: [...itemIds]用于将包含要删除项的数组作为参数传递给$pull操作符。 请注意,我们还需要设置{multi:true}选项来确保更新应用于所有文档,而不是仅更新第一个匹配项。