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);
  }
);

当前回答

还有一个:EMPTY const

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

其他回答

例如,您可以返回Observable.of(empty_variable)

Observable.of('');

// or
Observable.of({});

// etc

在我使用Angular2和rxjs的情况下,它与:

import {EmptyObservable} from 'rxjs/observable/EmptyObservable';
...
return new EmptyObservable();
...

因为所有的答案都过时了,我将在这里发布最新的答案

在 RXJS 中 >= 6

import { EMPTY } from 'rxjs'
return EMPTY;

或者您也可以尝试ignoreElements()

你可以用各种不同的方式返回空的可观察对象,但挑战是用预期的类型返回它 下面是创建一个类型为-的空观察对象的方法

intercept(req: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {
    
return next.handle(this.setHeaders(req))
            .pipe(
                catchError((error: HttpErrorResponse) => {
        // you write your logic and return empty response if required
        return new Observable<HttpEvent<any>>();
            }));
    }