文章来源于网络收集而来,版权归原创者所有,如有侵权请及时联系!
fromPromise
fromPromise
函数签名: fromPromise(promise: Promise, scheduler: Scheduler): Observable
创建由 promise 转换而来的 observable,并发出 promise 的结果。
打平类操作符可以接收 promises 而不需要 observable 包装!
你还可以使用 from 达到同样的效果!
示例
示例 1: 将 promise 转换成 observable 并捕获错误
import { of } from 'rxjs/observable/of';
import { fromPromise } from 'rxjs/observable/fromPromise';
import { mergeMap, catchError } from 'rxjs/operators';
// 基于输入来决定是 resolve 还是 reject 的示例 promise
const myPromise = willReject => {
return new Promise((resolve, reject) => {
if (willReject) {
reject('Rejected!');
}
resolve('Resolved!');
});
};
// 先发出 true,然后是 false
const source = of(true, false);
const example = source.pipe(
mergeMap(val =>
fromPromise(myPromise(val)).pipe(
// 捕获并优雅地处理 reject 的结果
catchError(error => of(`Error: ${error}`))
)
)
);
// 输出: 'Error: Rejected!', 'Resolved!'
const subscribe = example.subscribe(val => console.log(val));
其他资源
- fromPromise :newspaper: - 官方文档
- 创建操作符: from, fromArray, fromPromise :video_camera: :dollar: - André Staltz
- fromPromise - 指南
源码: https://github.com/ReactiveX/rxjs/blob/master/src/internal/observable/fromPromise.ts
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论