• race
    • 签名: race(): Observable
  • 使用首先发出值的 observable 。
    • 示例
      • 示例 1: 使用 4个 observables 进行 race
      • 示例 2: 使用 error 进行 race
  • 其他资源

    race

    签名: race(): Observable

    使用首先发出值的 observable 。

    race - 图1

    示例

    示例 1: 使用 4个 observables 进行 race

    ( StackBlitz |
    jsBin |
    jsFiddle )

    1. import { mapTo } from 'rxjs/operators';
    2. import { interval } from 'rxjs/observable/interval';
    3. import { race } from 'rxjs/observable/race';
    4. // 接收第一个发出值的 observable
    5. const example = race(
    6. // 每1.5秒发出值
    7. interval(1500),
    8. // 每1秒发出值
    9. interval(1000).pipe(mapTo('1s won!')),
    10. // 每2秒发出值
    11. interval(2000),
    12. // 每2.5秒发出值
    13. interval(2500)
    14. );
    15. // 输出: "1s won!"..."1s won!"...etc
    16. const subscribe = example.subscribe(val => console.log(val));
    示例 2: 使用 error 进行 race

    ( StackBlitz |
    jsFiddle )

    1. import { delay, map } from 'rxjs/operators';
    2. import { of } from 'rxjs/observable/of';
    3. import { race } from 'rxjs/observable/race';
    4. // 抛出错误并忽略其他的 observables 。
    5. const first = of('first').pipe(
    6. delay(100),
    7. map(_ => {
    8. throw 'error';
    9. })
    10. );
    11. const second = of('second').pipe(delay(200));
    12. const third = of('third').pipe(delay(300));
    13. race(first, second, third).subscribe(val => console.log(val));

    其他资源

    • race :newspaper: - 官方文档

    :file_folder: 源码: https://github.com/ReactiveX/rxjs/blob/master/src/internal/operators/race.ts