[RxJS] Use finalize for side effects on completion

Calling .unsubscribe()will NOT trigger completecallback!

const sub = interval(1000).subscribe({
  next: (val: any) => {
    counter.innerHTML = val;
  },
  complete: () => {
    counter.innerHTML = 'Stopped!' // <-- in this case, it won't run
  }
});

// calling unsubscribe will not trigger complete callbacks
setTimeout(() => {
  sub.unsubscribe();
}, 2000);

 

If you use take, takeUntil...those will trigger complete callback

// operators that complete observables will, like take and takeUntil
interval(1000).pipe(
  takeUntil(click$)
).subscribe({
  next: (val: any) => {
    counter.innerHTML = val;
  },
  complete: () => {
    counter.innerHTML = 'Stopped!' // <-- will run
  }
});

 

Use finalize

/*
 * You can also use finalize, which lets you run a function
 * on completion of the observable. This is good for misc side-effects,
 * but note, like tap, does not actually emit a returned item.
 * 
 * If you need to emit a final value on completion you can use
 * the endWith operator instead.
 */
interval(1000).pipe(
  takeUntil(click$),
  finalize(() => counter.innerHTML = 'Stopped!')
).subscribe((val: any) => counter.innerHTML = val);

 

works with throwError:

/*
 * finalize function will also be called if an error
 * occurs.
 */
throwError(new Error('Oops!')).pipe(
  takeUntil(click$),
  finalize(() => counter.innerHTML = 'Stopped!')
).subscribe((val: any) => counter.innerHTML = val);

 

posted @   Zhentiw  阅读(36)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
历史上的今天:
2020-10-18 [Kotlin Unit test] Spek & Mock
2019-10-18 [Flutter & Dart] Await a Future void function
2017-10-18 [AngularFire] Resolve snapshotChanges doesn't emit value when data is empty
2016-10-18 [CSS] Use CSS Counters to Create Pure CSS Dynamic Lists
2016-10-18 [CSS] Target empty elements using the :empty pseudo-class
2016-10-18 [Angular2 Animation] Basic animation
2016-10-18 [Angular2 Router] Auxiliary Routes bit by bit
点击右上角即可分享
微信分享提示