RXJS:聚合辩护

前端之家收集整理的这篇文章主要介绍了RXJS:聚合辩护前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我的用例如下:我得到的事件有时会爆发.如果发生爆发,我只需要处理一次.去抖动就是这样.

然而,debounce只给了我一个爆发的最后一个元素,但我需要知道一个爆发中的所有元素聚合在它们上面(使用flatmap).

这可以通过定时窗口或缓冲区来完成,但是,这些是固定间隔,因此缓冲区/窗口超时可能发生在突发中间,因此将突发分成2个部分而不是1.

所以我想要的是类似的东西

.
.
event: a
.
. -> a
.
.
.
.
.
.event: b
.event: c
.event: d
.
.-> b,c,d
. 
.
.
.
.event : e
.
. -> e
.
这可以通过将debounced流作为关闭选择器传递到 buffer来实现,例如:
var s = Rx.Observable.of('a')
  .merge(Rx.Observable.of('b').delay(100))
  .merge(Rx.Observable.of('c').delay(150))
  .merge(Rx.Observable.of('d').delay(200))
  .merge(Rx.Observable.of('e').delay(300))
  .share()
;

s.buffer(s.debounce(75)).subscribe(x => console.log(x));

这是一个可运行的版本:https://jsbin.com/wusasi/edit?js,output

猜你在找的设计模式相关文章