无法读取 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