如何通过键或值删除用户?
How do I remove a user by key or value?
我的 Firebase 数据库中有这样一个结构:
--users
--v7BwBnUBqJMXCtoOHYE51jXCwhY2: uid
--etc
当用户像这样通过身份验证时,用户 'table' 会填充:
loginFb() {
this.af.auth.login({
provider: AuthProviders.Facebook,
method: AuthMethods.Popup,
}).then(
(user) => {
this.userOnline(user.uid, 'uid');
this.router.navigate(['/members']);
}).catch(
(err) => {
this.error = err;
})
}
userOnline(uid, value) {
const users = this.af.database.object('/users');
users.update({ [uid]: value });
}
这为 ea 用户提供了用户 table 中由 fb 生成的 uid。
我想在用户注销时将其删除。研究这个我遇到了这个 .
我是这样应用的:
logout(userUID) {
this.af.auth.logout();
this.userOffline(userUID);
this.router.navigateByUrl('/login');
}
userOffline(userUID) {
const user = this.af.database.list('/', {
query: {
orderByChild: userUID,
equalTo: 'uid'
}
});
user.subscribe(snapshots=>{
snapshots.forEach(snapshot => {
console.log(snapshot);
snapshot.ref.remove();
});
})
}
console.log 的结果是:
Object {v7BwBnUBqJMXCtoOHYE51jXCwhY2: "uid", $key: "users"}
唉,我收到这个错误:
Cannot read property 'remove' of undefined
我确定有更好的方法来执行此操作,但我找不到任何方法。任何建议表示赞赏。
编辑
感谢@pengyy 的评论,我对他们的建议做了一个小修改。
user.subscribe(snapshots=>{
snapshots.forEach(snapshot => {
console.log(snapshot);
this.af.database.list('/users').remove(snapshot.userUID)
});
})
这有效并删除了用户,但它会在页面加载时立即执行此操作,即使在调用该函数时也不会...情节变粗了
通过
从 table 中删除项目
this.af.database.list('/users').remove(snapshot.$key)
userOffline(userUID) {
this.af.database.list('/users/'+userUID).remove();
}
所以这行得通。如此简单...
谢谢@pengyy 没有你的评论我不会到那里。
我的 Firebase 数据库中有这样一个结构:
--users
--v7BwBnUBqJMXCtoOHYE51jXCwhY2: uid
--etc
当用户像这样通过身份验证时,用户 'table' 会填充:
loginFb() {
this.af.auth.login({
provider: AuthProviders.Facebook,
method: AuthMethods.Popup,
}).then(
(user) => {
this.userOnline(user.uid, 'uid');
this.router.navigate(['/members']);
}).catch(
(err) => {
this.error = err;
})
}
userOnline(uid, value) {
const users = this.af.database.object('/users');
users.update({ [uid]: value });
}
这为 ea 用户提供了用户 table 中由 fb 生成的 uid。
我想在用户注销时将其删除。研究这个我遇到了这个
我是这样应用的:
logout(userUID) {
this.af.auth.logout();
this.userOffline(userUID);
this.router.navigateByUrl('/login');
}
userOffline(userUID) {
const user = this.af.database.list('/', {
query: {
orderByChild: userUID,
equalTo: 'uid'
}
});
user.subscribe(snapshots=>{
snapshots.forEach(snapshot => {
console.log(snapshot);
snapshot.ref.remove();
});
})
}
console.log 的结果是:
Object {v7BwBnUBqJMXCtoOHYE51jXCwhY2: "uid", $key: "users"}
唉,我收到这个错误:
Cannot read property 'remove' of undefined
我确定有更好的方法来执行此操作,但我找不到任何方法。任何建议表示赞赏。
编辑
感谢@pengyy 的评论,我对他们的建议做了一个小修改。
user.subscribe(snapshots=>{
snapshots.forEach(snapshot => {
console.log(snapshot);
this.af.database.list('/users').remove(snapshot.userUID)
});
})
这有效并删除了用户,但它会在页面加载时立即执行此操作,即使在调用该函数时也不会...情节变粗了
通过
从 table 中删除项目this.af.database.list('/users').remove(snapshot.$key)
userOffline(userUID) {
this.af.database.list('/users/'+userUID).remove();
}
所以这行得通。如此简单...
谢谢@pengyy 没有你的评论我不会到那里。