Angular How To Await Subscribe
Solution 1:
you can achieve this using toPromise method. It is also a great way to handle asynchronous operations. Just remove the subscribe and add this method and add the async keyword in the method from where you are calling this method.
Example-
const response = await this._roleService.getRoleTypes(this.token).toPromise();
So, Now you will get console.log("A") first then console.log("B").
Solution 2:
You should use async/await if you need synchronous execution of your code. Wrap your subscribe code in a function that returns a promise.
asyncgetRolestypes(): Promise<Array<RoleType>> {
returnnewPromise((resolve, reject) => {
this._roleService.getRoleTypes(this.token).subscribe(
response => {
if(response.status != "error" && response.code != 400){
let_roleTypes:Array<RoleType> = newArray<RoleType>();
_roleTypes = newArray<RoleType>();
response.data.forEach(rt => {
letroleType:RoleType = newRoleType(
rt.id,
rt.name
);
_roleTypes.push(roleType);
});
console.log("A");
console.log(_roleTypes);
resolve(_roleTypes);
}
else{
this._loginService.destroySession();
reject('not a good response')
}
},error => {
this.errorMessage = <any>error;
if(this.errorMessage != null){
reject(this.errorMessage);
}
}
);
})
}
this.roleTypes = awaitgetRolestypes();
console.log(this.roleTypes);
Solution 3:
As you may know, subscriptions are used to handle async method call. Thus, the code inside the subscribe() method is executed only when the async method return its result (after a http call for instance).
While waiting for the async response, the program continues and execute the following code. That's the goal of async calls!
That's why your console.log('B')
is executed before your console.log('A')
.
Here is an example:
this.myservice.asyncCall().subscribe( (result) => {
// wait for the async responseconsole.log('I get some data from asyncCall()');
});
// sync code executed, even if the previous async call doesn't respond anythingconsole.log('Code executed after the subscription. But not waiting for it to respond');
If you want you're console.log('B')
, you have to move it into your subscription function (after the else statement). You can also call a method from that location, depending on the purpose you're looking for.
You may take a look at the .map()
method as well. This allows you to edit the retrieved response before you handle it in the subscribe method (to add it some data, transform it, log or anything).
Solution 4:
@sunny answer above is my preferred choice. But toPromise
has been deprecated in RxJs 7 and won't probably be there
when RxJs 8 is released. So the new way would be:
import { lastValueFrom } from'rxjs';
const roleTypes$ = this._roleService.getRoleTypes(this.token);
const response = awaitlastValueFrom(roleTypes$);
Solution 5:
subscribe is executed asynchronously. In your case, subscribe will execute and then console.log('B') will get executed after that. When at a later point of time, the Observable posts the response (based on success/error), corresponding success/error callback will be invoked. so you can handle console.log('B') in in the success callback
Post a Comment for "Angular How To Await Subscribe"