停止Rxjs观察器的下一次执行?

时间:2018-12-13 11:13:01

标签: javascript node.js rxjs rxjs6

我正在尝试Rxjs观察器的基本用例。这就是我正在做的:

const { Observable } = require('rxjs');

Observable.create(o => { 
  setTimeout(() => o.next('hi'), 1000); 
  setTimeout(() => { throw new Error('A mistake') }, 1500); 
  setTimeout(() => o.next('this should not print'), 2000) }
).subscribe({
  next: x => console.log(x),
  error: y => console.log('error', y),
  complete: () => console.log('done')
});

其输出如下:

> hi
Error: A mistake
    at Timeout.setTimeout [as _onTimeout] (repl:1:89)
    at ontimeout (timers.js:498:11)
    at tryOnTimeout (timers.js:323:5)
    at Timer.listOnTimeout (timers.js:290:5)
> this should not print

我需要做的是停止下一次执行,即使我unsubscribe订阅也不会停止下一次执行。

我也尝试过这样:

让订阅;

let source = Observable.create(o => { 
  try {
    setTimeout(() => o.next('hi'), 1000); 
    setTimeout(() => { throw new Error('A mistake') }, 1500); 
    setTimeout(() => o.next('this should not print'), 2000) 
  } catch (e) {
    subscription.unsubscribe();
    return 'error';
  }
});
subscription = source.subscribe({
  next: x => console.log(x),
  error: y => console.log('error', y),
  complete: () => console.log('done')
});

但没有机会...它没有停止。

我所拥有的代码不只是设置超时,我还有一个异步等待代码,如下所示:

let subscription;

let source = Observable.create(async o => { 
  try {
    o.next(await anEvent()); 
    o.next(await anEventThatThrowsAnException()); 
    o.next(await anEventThatIWantToAvoidDueToTheException()); 
  } catch (e) {
    subscription.unsubscribe();
    return 'error';
  }
});
subscription = source.subscribe({
  next: x => console.log(x),
  error: y => console.log('error', y),
  complete: () => console.log('done')
});

如何实现此代码以停止“此不应该打印的内容”?

2 个答案:

答案 0 :(得分:1)

使用setTimeout设置计时器后,将不会阻止使用unsubscribe执行计时器。

您将需要手动清除超时。

请注意,您可以将超时保存到变量var myTimeout = setTimeout(f,ms);中,然后可以先取消clearTimeout(myTimeout);

了解更多:

答案 1 :(得分:1)

这是使其与ABOS所述的observer.error一起使用的方式。实际上,这就是他的示例,并且有效。

仅出于文档目的,我用评论中的答案回答了这个问题。

ABOS answer

我只是认为,如果有人在尝试处理错误时遇到问题,则抛出错误而不是按照需要的方式捕获并执行observer.error。