美文网首页
[转] RxJS: 6个你必须知道的操作符

[转] RxJS: 6个你必须知道的操作符

作者: wlianfu | 来源:发表于2017-07-22 22:28 被阅读45次

    转自: https://zhuanlan.zhihu.com/p/27997606

    1. concat
      // 模拟 HTTP 请求const getPostOne$ = Rx.Observable.timer(3000).mapTo({id: 1});const getPostTwo$ = Rx.Observable.timer(1000).mapTo({id: 2});Rx.Observable.concat(getPostOne$, getPostTwo$).subscribe(res => console.log(res));

    按顺序订阅 Observables,但是只有当一个完成并让我知道,然后才会开始下一个

    当顺序很重要时,使用此操作符,例如当你需要按顺序的发送 HTTP 请求时。

    1. forkJoin
      forkJoin 是 Rx 版的 Promise.all()
      const getPostOne$ = Rx.Observable.timer(1000).mapTo({id: 1});const getPostTwo$ = Rx.Observable.timer(2000).mapTo({id: 2});Rx.Observable.forkJoin(getPostOne$, getPostTwo$).subscribe(res => console.log(res))

    别让我知道直到所有的 Observables 都完成了,然后再一次性的给我所有的值。(以数组的形式)

    当你需要并行地运行 Observables 时使用此操作符。

    1. mergeMap
      const post$ = Rx.Observable.of({id: 1});const getPostInfo$ = Rx.Observable.timer(3000).mapTo({title: "Post title"});const posts$ = post$.mergeMap(post => getPostInfo$).subscribe(res => console.log(res));

    首先,我们得理解 Observables 世界中的两个术语:
    源 (或外部) Observable - 在本例中就是 post$ Observable 。
    内部 Observable - 在本例中就是 getPostInfo$ Observable 。

    仅当内部 Obervable 发出值时,通过合并值到外部 Observable 来让我知道。

    1. pairwise
      // 追踪页面滚动增量Rx.Observable .fromEvent(document, 'scroll') .map(e => window.pageYOffset) .pairwise() .subscribe(pair => console.log(pair)); // pair[1] - pair[0]

    当 Observable 发出值时让我知道,但还得给我前一个值。(以数组的形式)
    页面滚动…

    从输入 Observable 的第二个值开始触发。

    1. switchMap
      const clicks$ = Rx.Observable.fromEvent(document, 'click');const innerObservable$ = Rx.Observable.interval(1000);clicks$.switchMap(event => innerObservable$) .subscribe(val => console.log(val));

    类似于 mergeMap,但是当源 Observable 发出值时会取消内部 Observable 先前的所有订阅 。
    在我们的示例中,每次我点击页面的时,先前的 interval 订阅都会取消,然后开启一个新的。

    1. combineLatest
      const intervalOne$ = Rx.Observable.interval(1000);const intervalTwo$ = Rx.Observable.interval(2000);Rx.Observable.combineLatest( intervalOne$, intervalTwo$ ).subscribe(all => console.log(all));

    当任意 Observable 发出值时让我知道,但还要给我其他 Observalbes 的最新值。(以数组的形式)

    例如当你需要处理应用中的过滤器时,此操作符非常有用。

    如果你想了解更多关于 Observables 的内容,可以阅读我的文章:
    https://netbasal.com/javascript-observables-under-the-hood-2423f760584#.ptzobjg31*
    ") 0px 2px / cover;">*

    https://netbasal.com/understanding-subjects-in-rxjs-55102a190f3#.302oa6o3w*
    ") 0px 2px / cover;">*

    相关文章

      网友评论

          本文标题:[转] RxJS: 6个你必须知道的操作符

          本文链接:https://www.haomeiwen.com/subject/gucpkxtx.html