仅更新以JSON发送的字段

时间:2020-05-08 23:00:33

标签: node.js mongodb express mongoose

我有这段代码:

// Update a card    
router.patch('/:id', async (req, res) => {    
    try {    
        const card = await Card.findByIdAndUpdate(        
            {_id: req.params.id},    
            { $set: {    
                title: req.body.title,    
                description: req.body.description}},    
            { new: true });    
        res.json(card);    
    } catch (error) {    
        res.status(404).json({message: error});    
    }    
}); 

我希望能够分别更新标题和描述,这意味着如果我发送仅包含标题的JSON,则仅标题将被更新,问题在于如果我使用上面的代码执行此操作,因为说明丢失,然后说明将更新为null。有没有办法只更新我在JSON中发送的内容?

1 个答案:

答案 0 :(得分:0)

最后,我用这段代码解决了这个问题:

const $set = {};
    if(req.body.name)
        $set.name = req.body.name;
    if(req.body.background)
        $set.background = req.body.background;
    const board = await Board.findByIdAndUpdate(
        {_id: req.params.id},
        { $set },
        { new: true });