我正在尝试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')
});
如何实现此代码以停止“此不应该打印的内容”?
答案 0 :(得分:1)
使用setTimeout
设置计时器后,将不会阻止使用unsubscribe
执行计时器。
您将需要手动清除超时。
请注意,您可以将超时保存到变量var myTimeout = setTimeout(f,ms);
中,然后可以先取消clearTimeout(myTimeout);
了解更多:
答案 1 :(得分:1)
这是使其与ABOS所述的observer.error一起使用的方式。实际上,这就是他的示例,并且有效。
仅出于文档目的,我用评论中的答案回答了这个问题。
我只是认为,如果有人在尝试处理错误时遇到问题,则抛出错误而不是按照需要的方式捕获并执行observer.error。