总结的很到为!原文地址!收藏下,已被须要时查看!javascript
原文连接: netbasal.com/rxjs-six-op…java
// 模拟 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));
复制代码
当顺序很重要时,使用此操做符,例如当你须要按顺序的发送 HTTP 请求时。git
forkJoin
是 Rx 版的 Promise.all()
。github
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 时使用此操做符。数组
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 世界中的两个术语:post
post$
Observable 。getPostInfo$
Observable 。// 追踪页面滚动增量
Rx.Observable
.fromEvent(document, 'scroll')
.map(e => window.pageYOffset)
.pairwise()
.subscribe(pair => console.log(pair)); // pair[1] - pair[0]
复制代码
页面滚动…ui
从输入 Observable 的第二个值开始触发。spa
const clicks$ = Rx.Observable.fromEvent(document, 'click');
const innerObservable$ = Rx.Observable.interval(1000);
clicks$.switchMap(event => innerObservable$)
.subscribe(val => console.log(val));
复制代码
在咱们的示例中,每次我点击页面的时,先前的 interval
订阅都会取消,而后开启一个新的。code
const intervalOne$ = Rx.Observable.interval(1000);
const intervalTwo$ = Rx.Observable.interval(2000);
Rx.Observable.combineLatest(
intervalOne$,
intervalTwo$
).subscribe(all => console.log(all));
复制代码
例如当你须要处理应用中的过滤器时,此操做符很是有用。rxjs
若是你想了解更多关于 Observables 的内容,能够阅读个人文章: