架构师_程序员_码农网

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 1632|回复: 1

[Angular] RxJS finalize 操作符在 Observable 终止后执行逻辑

[复制链接]
发表于 2022-6-26 18:49:57 | 显示全部楼层 |阅读模式
需求:Angular 项目,当点击页面某个按钮的时候,会发送 HTTP 请求,由于一些接口比较耗时,需要显示加载动画效果,当 HTTP 请求完成关闭加载动画。当请求成功或者出现错误都需要关闭加载动画

常规写法

如下:

也就是当请求成功和发生错误都需要调用关闭加载动画,有没有更简单的方法呢?类似 c# 中的 try-catch-finally。

使用 finalize 运算符

它的作用就是 try-catch-finally 中 finally 的功能,我们只需要写一遍代码即可,无论成功和失败都会执行该逻辑。

代码如下:



finalize 如何工作?它基本上是通过订阅向可观察对象的拆卸添加回调 add(fn)。这保证了它将在错误、完成和取消订阅时被调用。

注意,只要我们的 Observable 终止,finalize 操作符就会被执行。这个很重要!对于 Angular HTTP,这非常有效,因为一旦请求完成,Angular HTTP 服务返回的“完成”。

(完)




上一篇:【实战】Fiddler 延迟接口响应时间和弱网测试
下一篇:使用 C# 提取 PDF 文件中的所有文字(支持 .NET Core)
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
 楼主| 发表于 2022-9-18 16:05:18 | 显示全部楼层
Angular RxJS 之 Subject 主题订阅
https://www.itsvse.com/thread-9209-1-1.html
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

免责声明:
码农网所发布的一切软件、编程资料或者文章仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。如有侵权请邮件与我们联系处理。

Mail To:help@itsvse.com

QQ|手机版|小黑屋|架构师 ( 鲁ICP备14021824号-2 )|网站地图

GMT+8, 2024-4-25 21:19

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表