【发布时间】:2016-07-14 05:05:25
【问题描述】:
使用 Rxjs 我需要在 Angular 服务中执行 4 个操作,然后组件使用该服务功能:
-调用函数“ensureHasCache():Observable”
-调用函数“create():Observable”
-取create()的结果并赋值一个局部变量(this._companies.push(newEntity);)
-然后返回一个 Observable 以便在 UI 上使用它
这是我执行 4 项操作的服务代码:
public create (data:Company):Observable<Company>
{
return this.ensureHasCache ().switchMap (res => {
return super.create (data);
}).switchMap ((newEntity:Company) => {
this._companies.push (newEntity);
return ObservableUtils.fromResult (newEntity);
});
}
正如您在最后一个 switchMap 中看到的,我需要返回一个可观察但 其实我已经有了结果。所以我必须调用“fromResult”。 但是这样我需要创建一个新的observalbe(“fromResult”创建一个新的Observable) 即使我真的不需要它。
还有更优雅的方式吗?
这是fromResult的代码:
public static fromResult<T> (result:T):Observable<T>
{
return new Observable<T> (obs => {
obs.next (result);
obs.complete ();
});
}
【问题讨论】:
标签: typescript angular rxjs rxjs5