如何从 firebase 获取数据作为 ionic 3 中项目数组的键数组
how to get data from firebase as array of key that array of item in ionic 3
我已经处理一个问题好几个小时了。
我正在尝试做下一件事:
我需要获取课程列表,课程是根据组课程定义的,我需要属于那个人的所有课程的数组。
结构在 firebase 中是这样的:
我真的搞砸了,想怎么写就怎么写,用MergeMap之类的。但这对我没有帮助。
请帮助我。
我的代码看起来像这样,我有一个供应商应该 return 我的课程列表。但我无法超越单身 mergeMap
.
在课程服务中:
getLessons(user: User): Observable<any[]>{
return this.database.list(`/lessons/${user.uid}`)
.mergeMap(key => this.database.list(`/lessons/${user.uid}/${key}`));
}
在课程页面:
private lessons: Lesson[];
ngOnInit(): void {
this.loader.present();
this.lessonService.getLessons(this.authenticatedUser)
.subscribe(_setLessonSet => {
_setLessonSet.forEach(set => {
set.forEach(lessonItem => {
this.lessons.push(lessonItem);
});
});
this.loader.dismiss();
});
}
我遇到了这个错误:
ERROR Error: Reference.child failed: First argument was an invalid path = "/lessons/eOqeJyTmQqQKa1bdzorMEDle4qD3/[object Object],[object Object]". Paths must be non-empty strings and can't contain ".", "#", "$", "[", or "]"
感谢各位帮手!
我找到了答案
getLessonSets(): Observable<LessonSet[]>{
if(!this.authenticatedUser) return new EmptyObservable<LessonSet[]>();
return this.database.list(`/lessonsLists/${this.authenticatedUser.uid}`);}
和循环,例如:
this.LessonSets = this.lessonService.getLessonSets();
this.lessonSetsArray = [];
this.LessonSets.forEach(LessonsetItem => {
LessonsetItem.forEach(OneLessonSet => {
this.lessonSetsArray.push(OneLessonSet);
});
});
并在视图(html 文件)中通过异步 pip 对此进行迭代
*ngFor="let LessonsetItem of LessonSets | async
谢谢大家
我已经处理一个问题好几个小时了。 我正在尝试做下一件事:
我需要获取课程列表,课程是根据组课程定义的,我需要属于那个人的所有课程的数组。
结构在 firebase 中是这样的:
我真的搞砸了,想怎么写就怎么写,用MergeMap之类的。但这对我没有帮助。 请帮助我。
我的代码看起来像这样,我有一个供应商应该 return 我的课程列表。但我无法超越单身 mergeMap
.
在课程服务中:
getLessons(user: User): Observable<any[]>{
return this.database.list(`/lessons/${user.uid}`)
.mergeMap(key => this.database.list(`/lessons/${user.uid}/${key}`));
}
在课程页面:
private lessons: Lesson[];
ngOnInit(): void {
this.loader.present();
this.lessonService.getLessons(this.authenticatedUser)
.subscribe(_setLessonSet => {
_setLessonSet.forEach(set => {
set.forEach(lessonItem => {
this.lessons.push(lessonItem);
});
});
this.loader.dismiss();
});
}
我遇到了这个错误:
ERROR Error: Reference.child failed: First argument was an invalid path = "/lessons/eOqeJyTmQqQKa1bdzorMEDle4qD3/[object Object],[object Object]". Paths must be non-empty strings and can't contain ".", "#", "$", "[", or "]"
感谢各位帮手!
我找到了答案
getLessonSets(): Observable<LessonSet[]>{
if(!this.authenticatedUser) return new EmptyObservable<LessonSet[]>();
return this.database.list(`/lessonsLists/${this.authenticatedUser.uid}`);}
和循环,例如:
this.LessonSets = this.lessonService.getLessonSets();
this.lessonSetsArray = [];
this.LessonSets.forEach(LessonsetItem => {
LessonsetItem.forEach(OneLessonSet => {
this.lessonSetsArray.push(OneLessonSet);
});
});
并在视图(html 文件)中通过异步 pip 对此进行迭代
*ngFor="let LessonsetItem of LessonSets | async
谢谢大家