具有间隔的Angular2 Observable

Dra*_*510 3 javascript intervals observable rxjs angular

我有一个需要每500ms调用一次的函数.我正在考虑使用angular2的方式是使用interval和observables.我试过这个函数来创建observable:

counter() {
  return Observable.create(observer => {
    setInterval(() => {
      return this.media.getCurrentPosition();
    }, 500)
  })
}
Run Code Online (Sandbox Code Playgroud)

使用此代码为订阅者:

test() {
  this.playerService.initUrl(xxxx) // This works
  this.playerService.counter().subscribe(data => {
    res => {
      console.log(data);
    }
  })
}
Run Code Online (Sandbox Code Playgroud)

我对于observables和angular2非常新,所以我可能完全采取了错误的方法.任何帮助表示赞赏.

rin*_*usu 14

Observable类有一个静态interval方法服用毫秒(如setInterval方法)作为参数:

counter() {
    return Observable
        .interval(500)
        .flatMap(() => {
            return this.media.getCurrentPosition();
        });
}
Run Code Online (Sandbox Code Playgroud)

在您的组件或任何地方:

test() {
  this.playerService.initUrl(xxxx) // This works
  this.playerService.counter().subscribe(
      data => {
          console.log(data);
      }
   );
}
Run Code Online (Sandbox Code Playgroud)

  • 只是给别人的一张纸条; `Observable.interval`是一个静态/类方法,你不能在Observable的实例上调用它(当我试图重复一个`http.get`时,我遇到了角度问题) (2认同)