我刚刚读了RxJS Promise Composition (passing data)这个问题,有一个问题.
设置与上述问题相同:我有3个诺言.
const p1 = () => Promise.resolve(1);
const p2 = x => { const val = x + 1; return Promise.resolve(val); };
const p3 = x => {
const isEven = x => x % 2 === 0;
return Promise.resolve(isEven(x));
};
根据答案,我将它们链接起来,如下所示:
var chainedPromises$=
Rx.Observable.just()
.flatMap(p1)
.flatMap(p2)
.flatMap(p3);
但是,chainedPromises $在所有promise链的末尾仅触发一次,且解析值为true.即:
chainedPromises$.subscribe(function(x){console.log(x)}); // Logs `true`
如何更改chainedPromises $,以便在每个承诺结束时触发一次?即:
chainedPromises$.subscribe(function(x){console.log(x)});
// Logs `1`
// Logs `2`
// Logs `true`
解决方法:
看起来您需要发出生成的值并在链的下一步中使用它.我不知道这是否有糖,但是我通过明确区分来使它起作用.
Observable
.fromPromise(p1())
.flatMap(val => Observable.merge(
Observable.fromPromise(p2(val))
.flatMap(val => Observable.merge(
Observable.fromPromise(p3(val)),
Observable.of(val)
)),
Observable.of(val)
))
.subscribe(console.log);
您可以看到it正常工作.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。