timeout

在指定时间间隔内不投射值就报错。

用法

timeout<T>(
  due: number | Date,
  scheduler: SchedulerLike = async
): MonoTypeOperatorFunction<T>

参数

参数说明
due超时时间或日期。
scheduler可选,默认值: async。 类型: SchedulerLike

返回

类型: MonoTypeOperatorFunction<T>

示例

2.5s 超时

import { of } from 'rxjs';
import { concatMap, timeout, catchError, delay } from 'rxjs/operators';

// 模拟请求
function makeRequest(timeToDelay) {
  return of('Request Complete!').pipe(delay(timeToDelay));
}

of(4000, 3000, 2000)
  .pipe(
    concatMap(duration =>
      makeRequest(duration).pipe(
        timeout(2500),
        catchError(error => of(`Request timed out after: ${duration}`))
      )
    )
  )
  /*
   * 输出:
   *  "Request timed out after: 4000"
   *  "Request timed out after: 3000"
   *  "Request Complete!"
   */
  .subscribe(val => console.log(val));

源码

https://github.com/ReactiveX/rxjs/blob/master/src/internal/operators/timeout.ts

在 GitHub 上编辑此页面 article.updatedAt Wed, Aug 11, 2021