【发布时间】:2016-09-15 05:00:24
【问题描述】:
我对 TypeScript 和 RxJS 还是很陌生,我正在尝试在另一个 Observable 完成后返回一个 Observable:
public myObservable = () : Observable<boolean> => {
console.log('retrieving the token in DB');
return Observable.create(observer => {
setTimeout(() => {
observer.next(true);
observer.complete();
}, 5000);
});
}
public makeRequest = (): Observable<any> => {
return this.myObservable().subscribe(
function (x) {
console.log('I have the token, now I can make the HTTP call');
return this.http.get('http://jsonplaceholder.typicode.com/posts/1')
.map( (responseData) => {
return responseData.json();
})
.map((item:any) => {
return {
id: item.id,
userId: item.userId,
title: item.title,
body: item.body
};
});
},
function (err) {
console.error('Error: ' + err);
},
function () {
console.log('Completed');
});
}
我收到此错误:“返回的表达式类型订阅不可分配给类型 Observable<any>”。
我完全理解这里的错误(Observable 就像一个流,而订阅是“观察”该流的事实),但我不知道如何“等待” Observable (或承诺) 完成以返回新的 Observable。我该怎么做?
【问题讨论】:
-
很好的提示!我的 2 美分:flatMap() 似乎在 rxjs 5.0.1 中不可用。我使用 mergeMap() 来实现可观察对象的“链”,或者换句话说 - 有一个外部和 2 个内部可观察对象。
标签: typescript rxjs observable