开发者问题收集

无法读取 collection.set() 上未定义的属性 afs(Angularfirestore)

2019-04-12
437

我使用以下代码来迭代数据集合,并在电子邮件匹配时更改字段。请注意,代码在设置时崩溃。迭代工作正常。afs 初始化为 AngularFirestore

onChangeRole(email) {
  this.afs.collection("users").get().toPromise().then(function (querySnapshot) {
    querySnapshot.forEach(function (doc) {
      // doc.data() is never undefined for query doc snapshots
      console.log(doc.id, " => ", doc.data());

      if (doc.data().email == email) {
        this.afs.collection("users").doc(doc.id).set({
          role: 2
        })
      }
    });
  });
}

但我收到:

ERROR Error: Uncaught (in promise): TypeError: Cannot read property 'afs' of undefined TypeError: Cannot read property 'afs' of undefined

其中 afs 是 AngularFirestore

import { AngularFirestore, AngularFirestoreCollection , AngularFirestoreDocument} from '@angular/fire/firestore';
2个回答

您必须在构造函数中对其进行初始化,然后才能像尝试的那样将其与 this.afs 一起使用。

例如:

constructor(private afs: AngularFirestore) { }

编辑: 更改箭头函数用法的功能词:

this.afs.collection("users").get().toPromise().then( querySnapshot => {
      querySnapshot.forEach( doc => {
        // doc.data() is never undefined for query doc snapshots
        console.log(doc.id, " => ", doc.data());

        if (doc.data().email == email) {
          this.afs.collection("users").doc(doc.id).set({
            role: 2
          })
        }
      });
    });
RadW2020
2019-04-12

这应该可行

onChangeRole(email) {
  const usersColl = this.afs.collection("users");
  usersColl.get().toPromise().then(function (querySnapshot) {
    querySnapshot.forEach(function (doc) {
      console.log(doc.id, " => ", doc.data());
      if (doc.data().email == email) {
        usersColl.doc(doc.id).set(
          { role: 2 },
          { merge: true }
        )
      }
    });
  });
}
Sourav Dutta
2019-04-12