2.4 KiB
2.4 KiB
id | title | challengeType | forumTopicId | dashedName |
---|---|---|---|---|
587d7fb8367417b2b2512c0e | 通过执行查询、编辑、保存来执行经典更新流程 | 2 | 301541 | perform-classic-updates-by-running-find-edit-then-save |
--description--
在过去,如果想要编辑 document 并以某种方式使用它(比如放到服务器的返回数据中),就必须执行查找、编辑和保存。 Mongoose 有一个专用的更新方法 Model.update()
, 它与底层的 mongo 驱动绑定。 通过这个方法,我们可以批量编辑符合特定条件的多个 document。但问题在于,这个方法不会返回更新后的 document,而是返回状态信息。 此外,它直接调用 mongo 的底层驱动,让处理 model 的验证变得更加棘手。
--instructions--
在这个挑战中,请使用参数 personId
作为字段,修改 findEditThenSave
方法,以在数据库中通过 _id
找到相应的 person(你可以使用之前挑战中的任何一种方法)。 将 "hamburger"
添加到它的 favoriteFoods
清单中(你可以使用 Array.push()
)。 然后,在查询数据库的方法的回调里通过 save()
方法更新 Person
的数据。
提示: 如果你在 Schema 中将 favoriteFoods
声明为一个 Array(数组)并且没有指定数组的类型(如 [String]
), 那么此时,favoriteFoods
就会是默认的 Mixed 类型。如果想编辑它,就必须执行 document.markModified('edited-field')
。 详情请参阅 Mongoose 文档
--hints--
应成功地对一条数据进行查找、编辑和更新
(getUserInput) =>
$.post(getUserInput('url') + '/_api/find-edit-save', {
name: 'Poldo',
age: 40,
favoriteFoods: ['spaghetti']
}).then(
(data) => {
assert.equal(data.name, 'Poldo', 'item.name is not what is expected');
assert.equal(data.age, 40, 'item.age is not what expected');
assert.deepEqual(
data.favoriteFoods,
['spaghetti', 'hamburger'],
'item.favoriteFoods is not what expected'
);
assert.equal(data.__v, 1, 'The item should be previously edited');
},
(xhr) => {
throw new Error(xhr.responseText);
}
);
--solutions--
/**
Backend challenges don't need solutions,
because they would need to be tested against a full working project.
Please check our contributing guidelines to learn more.
*/