Angular 2: Преобразование наблюдаемых в обещание
Q) Как преобразовать следующее наблюдаемое в обещание, чтобы я мог называть его .then(...)
?
Мой метод, который я хочу преобразовать в обещание:
this._APIService.getAssetTypes().subscribe(
assettypes => {
this._LocalStorageService.setAssetTypes(assettypes);
},
err => {
this._LogService.error(JSON.stringify(err))
},
() => {}
);
Используемый метод службы:
getAssetTypes() {
var method = "assettype";
var url = this.apiBaseUrl + method;
return this._http.get(url, {})
.map(res => <AssetType[]>res.json())
.map((assettypes) => {
assettypes.forEach((assettypes) => {
// do anything here you might need....
});
return assettypes;
});
}
Спасибо!
Ответы
Ответ 1
import 'rxjs/add/operator/toPromise';
import 'rxjs/add/operator/map';
...
this._APIService.getAssetTypes()
.map(assettypes => {
this._LocalStorageService.setAssetTypes(assettypes);
})
.toPromise()
.catch(err => {
this._LogService.error(JSON.stringify(err));
});
Ответ 2
вам действительно не нужно это делать, просто...
import 'rxjs/add/operator/first';
this.esQueryService.getDocuments$.first().subscribe(() => {
event.enableButtonsCallback();
},
(err: any) => console.error(err)
);
this.getDocuments(query, false);
first() гарантирует, что блок подписки будет вызываться только один раз (после чего он будет как если бы вы никогда не подписались), точно так же, как promises then()
Ответ 3
наблюдаемый может быть преобразован в обетование следующим образом:
let promise=observable.toPromise();