javascript - How to switch to another Observable when a source Observable emits but only use latest value - Stack Overflow

I have two observablesload$ is a stream of load events, emitted on startup or when a reload button is c

I have two observables

  • load$ is a stream of load events, emitted on startup or when a reload button is clicked
  • selection$ is a stream of selected list items, emitted when a list item is selected

I'm wondering if there is an operator that lets me (A) get the latest value emitted by selection$ whenever load$ emits, while (B) ignoring the value emitted by load$.

I was able to acplish (A) by using withLatestFrom but that doesn't satisfy (B) because withLatestFrom does not ignore the source observable.

load$.withLatestFrom(selection$).subscribe(([_, latestSelection) => {
  // _ is not needed and I don't like to write code like this
  // I only need the latest selection
});

I've looked at switchMapTo which satisfies (B) but not (A) without also using first() or take(1).

load$.switchMapTo(selection$.take(1)).subscribe(latestSelection => {
  // I would like to avoid having to use take(1)
});

I'm looking for a hypothetical switchMapToLatestFrom operator.

load$.switchMapToLatestFrom(selection$).subscribe(latestSelection => {
  // switchMapToLatestFrom doesn't exist :(
});

Unfortunately it doesn't exist and I don't like the two other ways that I came up with because it's not immediately obvious why the code contains take(1) or unused arguments.

Are there any other ways to bine two observables so that the new observable emits only the latest value from the second observable whenever the first observable emits?

I have two observables

  • load$ is a stream of load events, emitted on startup or when a reload button is clicked
  • selection$ is a stream of selected list items, emitted when a list item is selected

I'm wondering if there is an operator that lets me (A) get the latest value emitted by selection$ whenever load$ emits, while (B) ignoring the value emitted by load$.

I was able to acplish (A) by using withLatestFrom but that doesn't satisfy (B) because withLatestFrom does not ignore the source observable.

load$.withLatestFrom(selection$).subscribe(([_, latestSelection) => {
  // _ is not needed and I don't like to write code like this
  // I only need the latest selection
});

I've looked at switchMapTo which satisfies (B) but not (A) without also using first() or take(1).

load$.switchMapTo(selection$.take(1)).subscribe(latestSelection => {
  // I would like to avoid having to use take(1)
});

I'm looking for a hypothetical switchMapToLatestFrom operator.

load$.switchMapToLatestFrom(selection$).subscribe(latestSelection => {
  // switchMapToLatestFrom doesn't exist :(
});

Unfortunately it doesn't exist and I don't like the two other ways that I came up with because it's not immediately obvious why the code contains take(1) or unused arguments.

Are there any other ways to bine two observables so that the new observable emits only the latest value from the second observable whenever the first observable emits?

Share Improve this question asked Jul 13, 2017 at 9:35 Steven LiekensSteven Liekens 14.1k9 gold badges66 silver badges94 bronze badges
Add a ment  | 

2 Answers 2

Reset to default 11

withLatestFrom takes an optional project function that's passed the values.

You can use it to ignore the value from load$ and emit only the latest selection:

load$
  .withLatestFrom(selection$, (load, selection) => selection)
  .subscribe(selection => {
    // ...
  });

use "sample" operator In your case:

selection$.pipe(sample(load$)).subscribe(
   // the code you want to run
)

发布者:admin,转转请注明出处:http://www.yc00.com/questions/1743694829a4491579.html

相关推荐

发表回复

评论列表(0条)

  • 暂无评论

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信