Angular 4:使用HTTP拦截器+RxJS超时运算符错误

Fel*_*Fel 4 rxjs angular-http-interceptors angular

我尝试为使用 HttpClient 执行的每个 HTTP 请求设置 10 秒的默认超时。我有一个拦截器可以向标头添加一些值,并且我已经读到要设置超时,您必须使用“超时”RxJS 运算符,如下所示:

import { Injectable } from '@angular/core';
import { HttpEvent, HttpInterceptor, HttpHandler, HttpRequest, HttpHeaders } from '@angular/common/http';

import { Observable } from 'rxjs/Observable';
import { timeout } from 'rxjs/operators/timeout';

@Injectable()
export class APIInterceptor implements HttpInterceptor {
  constructor() {

  }

  intercept (req: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {

    // NOTE: The following 'authToken' and 'user_id' values are obtained through a global service
    const authReq = req.clone({
      headers: new HttpHeaders ({
        'Content-Type':  'application/json',
        'X_TOKEN_AUTH': authToken,
        'X_IDUSER': user_id
      }) 
    });

    const API_TIMEOUT = 10000;

    //console.log('HEADER: ', authReq)

    return next.handle(authReq).timeout(API_TIMEOUT);   // Set a timeout for the requests
  }
}
Run Code Online (Sandbox Code Playgroud)

在添加超时功能之前,一切正常,标头中注入了身份验证令牌和用户 ID。但是,现在我收到以下错误:

next.handle(...).timeout 不是一个函数

难道我做错了什么?谢谢!

mar*_*tin 5

如果您想使用“补丁”样式的运算符,您需要从以下位置导入它rxjs/add/operator/*

import 'rxjs/add/operator/timeout';
Run Code Online (Sandbox Code Playgroud)

'rxjs/operators/timeout'使用时使用该方法pipe()