5

我从按钮单击事件创建了一个流。该按钮对应于数据库上的创建操作。显然,我希望数据库操作只触发一次(至少在它完成之前)。有没有办法在返回createButtonStream之前忽略事件Api.create?即,第一个事件应该调用#Api.create,后续事件应该被忽略,直到#Api.create 返回。

createButtonStream
   .flatMap(() => Api.create()) //Needs to fire once until doSomething() is called
   .onValue(result => doSomething(result))

想到的唯一方法是使用全局状态......我宁愿不这样做。

//i don't wanna do this
let condition = true

createButtonStream
   .filter(() => condition)
   .map(() => condition = false)
   .flatMap(() => Api.create())
   .onValue(result => {condition = true; doSomething(result)})
4

2 回答 2

3

RxJS你使用flatMapFirstorexhaustMap运算符(如果使用 RxJS 5)

createButtonStream
   .flatMapFirst(() => Api.create())       
   .subscribe(result => doSomething(result));

flatMapFirst如果事件在第一个源完成之前到达,将静默删除事件,则不应调用该方法。

于 2016-05-25T19:56:06.580 回答
0

您可以使用等待。你需要一辆公共汽车来解决先有鸡还是先有蛋的问题。

const filterBus = new Bacon.Bus()

const createDone = createButtonStream
  .filter(filterBus.toProperty(true))
  .flatMap(() => Api.create())

const inProgress = createButtonStream.awaiting(createDone)
filterBus.plug(inProgress.not())

createDone.onValue(doSomething)
于 2016-05-25T12:38:17.437 回答