more()函数应该从get请求返回一个可观察对象

export class Collection {
  public more = (): Observable<Response> => {
    if (this.hasMore()) {
      return this.fetch();
    } else {
      // return empty observable
    }
  };

  private fetch = (): Observable<Response> => {
    return this.http.get("some-url").map((res) => {
      return res.json();
    });
  };
}

在这种情况下,我只能做一个请求,如果hasMore()为真,否则我得到一个错误订阅()函数订阅没有定义,我怎么能返回一个空的可观察对象?

this.collection.more().subscribe(
  (res) => {
    console.log(res);
  }, (err) => {
    console.log(err);
  }
);

当前回答

返回空可观察对象的不同方法:

Observable.from ({}); Observable.of ({}); 空

https://www.learnrxjs.io/learn-rxjs/operators/creation/empty

其他回答

或者您也可以尝试ignoreElements()

还有一个:EMPTY const

替换为EMPTY常量或scheduled(例如scheduled([], scheduler))。将在v8中删除。(得到这个表单phpstorm提示)

是的,有一个空操作符

Rx.Observable.empty();

对于typescript,你可以使用from:

Rx.Observable<Response>.from([])

带着一个类似的问题来到这里,上面的问题对我不起作用:“rxjs”:“^6.0.0”,为了生成一个不释放我需要做的数据的可观察对象:

import {Observable,empty} from 'rxjs';
class ActivatedRouteStub {
  params: Observable<any> = empty();
}

RxJS 6

你可以像下面这样使用also from函数:

return from<string>([""]);

导入后:

import {from} from 'rxjs';