Cloud Firestore:使用动态键更新嵌套对象中的字段
Cloud Firestore: Update fields in nested objects with dynamic key
遵循firestore的官方文档:
{
name: "Frank",
favorites: { food: "Pizza", color: "Blue", subject: "recess" },
age: 12
}
// To update favorite color:
db.collection("users").doc("frank").update({
"favorites.color": "Red"
})
我想使用动态键而不是颜色。
db.collection("users").doc("frank").update({
"favorites[" + KEY + "].color": true
});
这当然不可能,会报错。
我一直在尝试这样做:
db.collection("users").doc("frank").update({
favorites: {
[key]: {
color": true
}
}
});
它实际上是用正确的密钥更新,但不幸的是,它正在覆盖其他密钥(它们正在被删除)。
我找到了受 firebase 解决方案启发的解决方案(将“/”替换为“.”)。
var usersUpdate = {};
usersUpdate[`favorites.${key}.color`] = true;
db.collection("users").doc("frank").update(usersUpdate);
这个解决方案对我有用:
db.collection('users').doc('frank').update({
[`favorites.${key}.color`]: true
});
您可以更新变量(ly)命名的嵌套对象的特定字段,如下所示。
ref.set({
name: "Frank",
favorites: { food: "Pizza", quantity: 2 }
});
//now the relevant update code
var name = "favorites";
var qty = 111;
var update = {};
update[name+".quantity"] = qty;
ref.update(update);
注意一个潜在的陷阱:在发现可以使用点语法更新嵌套字段后,我尝试以相同的方式使用 set()
,因为无论对象是否已经存在,我都需要它来工作不是:
var updateObj = {['some.nested.property']: 9000};
docRef.set(updateOb, {merge: true});
不幸的是,这不起作用——它设置了一个 属性,其键是 some.nested.property
。不一致,但还可以。
幸运的是,set(updateObj, {merge: true})
似乎进行了深度合并,因此如果您将更新对象构造为完全嵌套的对象,您的嵌套对象也将被正确合并:
// create the object
db.doc('testCollection/doc').set({p1: {['p2']: {p3: true}}}, {merge: true})
// update the existing object
db.doc('testCollection/doc').set({p1: {['p2']: {p4: true}}}, {merge: true})
// result is now this:
{ p1: { p2: { p4: true, p3: true } } }
我觉得这是上述所有解决方案中最简单的解决方案:)
db.collection("users").doc("frank").update({
[`favorites.${KEY}.color`]: true
});
你可以使用
var auxKey = "history." + someVar;
var dataToUpdate = {
[auxKey]: "new data generated"
};
db.collection("users").doc("frank").update(dataToUpdate);
遵循firestore的官方文档:
{
name: "Frank",
favorites: { food: "Pizza", color: "Blue", subject: "recess" },
age: 12
}
// To update favorite color:
db.collection("users").doc("frank").update({
"favorites.color": "Red"
})
我想使用动态键而不是颜色。
db.collection("users").doc("frank").update({
"favorites[" + KEY + "].color": true
});
这当然不可能,会报错。
我一直在尝试这样做:
db.collection("users").doc("frank").update({
favorites: {
[key]: {
color": true
}
}
});
它实际上是用正确的密钥更新,但不幸的是,它正在覆盖其他密钥(它们正在被删除)。
我找到了受 firebase 解决方案启发的解决方案(将“/”替换为“.”)。
var usersUpdate = {};
usersUpdate[`favorites.${key}.color`] = true;
db.collection("users").doc("frank").update(usersUpdate);
这个解决方案对我有用:
db.collection('users').doc('frank').update({
[`favorites.${key}.color`]: true
});
您可以更新变量(ly)命名的嵌套对象的特定字段,如下所示。
ref.set({
name: "Frank",
favorites: { food: "Pizza", quantity: 2 }
});
//now the relevant update code
var name = "favorites";
var qty = 111;
var update = {};
update[name+".quantity"] = qty;
ref.update(update);
注意一个潜在的陷阱:在发现可以使用点语法更新嵌套字段后,我尝试以相同的方式使用 set()
,因为无论对象是否已经存在,我都需要它来工作不是:
var updateObj = {['some.nested.property']: 9000};
docRef.set(updateOb, {merge: true});
不幸的是,这不起作用——它设置了一个 属性,其键是 some.nested.property
。不一致,但还可以。
幸运的是,set(updateObj, {merge: true})
似乎进行了深度合并,因此如果您将更新对象构造为完全嵌套的对象,您的嵌套对象也将被正确合并:
// create the object
db.doc('testCollection/doc').set({p1: {['p2']: {p3: true}}}, {merge: true})
// update the existing object
db.doc('testCollection/doc').set({p1: {['p2']: {p4: true}}}, {merge: true})
// result is now this:
{ p1: { p2: { p4: true, p3: true } } }
我觉得这是上述所有解决方案中最简单的解决方案:)
db.collection("users").doc("frank").update({
[`favorites.${KEY}.color`]: true
});
你可以使用
var auxKey = "history." + someVar;
var dataToUpdate = {
[auxKey]: "new data generated"
};
db.collection("users").doc("frank").update(dataToUpdate);