Я использую Angular 6, и моя база данных - Firebase.Сейчас я пытаюсь показать каждое из названий комнаты в соответствии с ее строением.Например:
Building A
Room 1
Room 2
Building B
Room 1
Room 2
Но каждый раз, когда я пытаюсь, сначала будут показываться все названия зданий, а только потом - имена комнат.Вот что я получил сейчас:
Building A
Building B
Room 1
Room 2
Я обнаружил, что это происходит, потому что forEach
продолжает пропускать функцию subscribe
.
Я пытался использовать promise
и await
, но это не работает.Может потому, что я использую это неправильно?Я не совсем уверен, как правильно использовать promise
.
async loadData(){
this.navigationService.user
.subscribe( user => {
console.log(user);
this.user = user;
this.navigationService.getBuildings(this.user.orgId)
.subscribe( building => {
this.navMasterBuilding = [];
this.buildings = building;
this.buildings.forEach( async building2 => {
this.completeBuildingId = building2.completeBuildingId;
this.buildingName = building2.buildingName;
console.log(building2.buildingName);
await new Promise ((resolve, reject) => {
this.navigationService.getLocation(this.user.orgId, this.completeBuildingId)
.subscribe(location => {
console.log('room' + location);
this.navMasterLocation = [];
});
resolve();
});
});
});
});
}
Я пытался отложить его, используя setTimeout, но он все равно не работает.