RxJS switchMap不会取消内部合并的observable

时间:2018-02-15 19:41:21

标签: rxjs unsubscribe switchmap

内部合并的observable没有以此代码终止(rxjs 5.5.6):

    let source = new Subject<string[]>();

    // when the source emits a vector of strings, output 
    // each string with a 1s delay
    source.switchMap(v => Observable.from(v)
        .map(s => Observable.of(s).delay(1000).do(s => console.log('do: ' + s)))
        // only one active observable at time  
        .mergeAll(1) 
    ).subscribe(val => console.log('result: ' + val));

    // emit two vectors, 1.5s apart
    Observable.interval(1500).take(2).map(i => ['a' + i, 'b' + i, 'c' + i])
        .subscribe(v => source.next(v));

输出是:

do: a0
result: a0
do: b0
do: a1
result: a1
do: c0
do: b1
result: b1
do: c1
result: c1

预期输出为:

do: a0
result: a0
do: a1
result: a1
do: b1
result: b1
do: c1
result: c1

也就是说,在第二个向量发出之后,switchMap应取消订阅第一个向量上的observable,取消该可观察对象。虽然取消订阅显然正在运行,但内部可观察性仍然在运行,作为第一个示例输出中“do:a0 ... b0 ... c0”的证据。

事实上,预期输出正是您从此代码中获得的结果:

    let source = 
        Observable.interval(1500).take(2).map(i => ['a' + i, 'b' + i, 'c' + i]);

    source.switchMap(v => Observable.from(v)
        .map(s => Observable.of(s).delay(1000).do(s => console.log('do: ' + s)))
        .mergeAll(1)
    ).subscribe(val => console.log('result: ' + val));

但为什么第一个例子的行为方式不一样呢?

0 个答案:

没有答案