gpt4 book ai didi

javascript - 为什么 `finally` 在这种情况下在 RxJS 中不起作用?

转载 作者:行者123 更新时间:2023-11-28 18:41:20 24 4
gpt4 key购买 nike

这不会打印“drag end”:

mouseDrags.forEach(drag => {
console.log('drag start');
drag.finally(_ => console.log('drag end'));
drag.forEach(doSomething);
});

但这会打印“drag end”:

mouseDrags.forEach(drag => {
console.log('drag start');
drag.finally(_ => console.log('drag end')).forEach(_=>_);
drag.forEach(doSomething);
});

为什么 forEach 会有所不同?

最佳答案

这是因为.finally()返回了另一个你需要订阅的Observable。 Observable 默认情况下是惰性的,因此在被订阅之前它们不会开始发射。

所以你可以这样做

mouseDrags.forEach(drag => {
console.log('drag start');
drag.finally(_ => console.log('drag end')).forEach(doSomething);
});

甚至更好

mouseDrags.flatMap(drag => {
console.log('drag start');
return drag.finally(_ => console.log('drag end'))
}).forEach(doSomething);

关于javascript - 为什么 `finally` 在这种情况下在 RxJS 中不起作用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36020588/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com