您如何根据索引精确地更新列表中的特定值?例如,在下面的列表中:
0 [ { first_name: name0, last_name: lastName0, } ] 1 [ { first_name: name1, last_name: lastName1, } ]
如何仅更新“ lastName1”?目前,我正在使用一些有点麻烦的解决方案,使用ArrayUnion,该解决方案使用数据比较而不是实际的索引(我将值加载到表单中,删除了原始值,然后再次将其重新添加):
// Retrieve data at index, load into form // Remove that index from List await Firestore.instance.collection(col).document(doc).updateData({ 'people': FieldValue.arrayRemove([person]) }); // Make changes to data via form // Save back to list await Firestore.instance.collection(col).document(doc).updateData({ 'people': FieldValue.arrayUnion([person]) });
有没有可以让我指定要更新哪个特定索引数据的功能?诸如此类(但使用列表而不是地图):
await Firestore.instance.collection(col).document(doc).updateData({ 'people.$index.lastName1': 'newName') });
对于所有客户端语言和平台,当前不可能发出单个命令来按索引更新数组项。对此没有特殊的语法。相反,您需要做的是阅读文档,以所需的方式修改字段数组数据,然后将该字段全部更新回文档。如果您希望更新是原子更新,则可以在事务中执行此操作。