RxJS 错误处理:从基础到实践
1. 传统错误处理的局限性
在处理异步操作时,Promise 虽然能让我们更接近目标,但它也存在一些局限性。它限制了代码的响应式和反应式能力,例如在请求失败时难以轻松返回默认值,或者重试被拒绝的 Promise。若要传递默认值,可能需要在代码中引入副作用;而实现重试则需借助第三方库。
此外,Promise 只能处理单个异步值,无法应对大量异步值的情况,这在函数式和反应式编程中是常见问题。而且,如果没有提供错误处理程序,Promise 可能会吞掉异常。
传统的命令式错误处理技术,如在 JavaScript 中使用 try/catch 块,在函数式或反应式代码中有诸多缺点:
- 无法组合或链式调用 :抛出异常的函数不能像其他函数式构件一样进行组合或链式调用。
- 违背纯函数原则 :纯函数应返回单一、可预测的值,而抛出异常为函数调用开辟了另一条退出路径。
- 导致副作用 :栈的意外展开会影响整个系统,而非仅仅是函数调用或流声明。
- 违背非局部性原则 :用于从错误中恢复的代码与原始函数调用距离较远。例如:
try {
let record = findRecordById('123');
// ... 中间可能有很多行代码
}
catch (e) {
console.log('ERROR: Record not foun
超级会员免费看
订阅专栏 解锁全文
501

被折叠的 条评论
为什么被折叠?



