2

我有一个包含多个图层子文档的地图文档,并且想要实现 HTTP PATCH,因此只有给定的 JSON 属性才能更新图层子文档。以下代码有效,但我必须指定每个可以更改的属性。有更好的方法吗?

var update = {};
if (req.body.name !== undefined)
    update['layers.$.name'] = req.body.name;
if (req.body.isDefault !== undefined)
    update['layers.$.isDefault'] = req.body.isDefault;
if (req.body.isPublic !== undefined)
    update['layers.$.isPublic'] = req.body.isPublic;

Map.model.findOneAndUpdate({_id: req.params.mapId, 'layers._id': req.params.layerId}, update, callback);
4

2 回答 2

1

您可以制作这样的功能:

function updateParams(reqParams,additionalInfo)
{
    var update = {};
    for(var paramName in reqParams)
    {
        if(reqParams.hasOwnProperty(paramName))
        {
            if(reqParams[paramName]!==undefined)
            {
                update[additionalInfo+paramName] = reqParams[paramName];
            }
        }
    }
    return update;

}

updateParams(req.body,'layers.$.');
于 2013-01-14T15:11:57.337 回答
0

我有你考虑过 JsonPatch 这个项目将 json 补丁转换为 mongo 原子更新:jsonpatch-to-mongodb

于 2015-02-15T23:01:35.453 回答