Cloud Firestore:使用动态密钥更新嵌套对象中的字段

时间:2017-11-14 21:30:13

标签: javascript firebase google-cloud-firestore

遵循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
        }
    }
});

实际上是使用正确的密钥进行更新,但不幸的是,它正在覆盖其他密钥(它们正被删除)。

4 个答案:

答案 0 :(得分:51)

我发现解决方案受到了firebase解决方案的启发(取代" /""。")。

var usersUpdate = {};
usersUpdate[`favorites.${key}.color`] = true;

db.collection("users").doc("frank").update(usersUpdate);

答案 1 :(得分:10)

这个解决方案对我有用:

db.collection('users').doc('frank').update({
  ['favorites.' + key + '.color']: true
});

答案 2 :(得分:4)

请注意一个潜在的陷阱:发现可以使用点语法更新嵌套字段后,我尝试使用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 } } }

答案 3 :(得分:1)

您可以更新名为嵌套对象的变量(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);

https://jsbin.com/hihifedizu/edit?js,console