码迷,mamicode.com
首页 > Web开发 > 详细

[RxJS] Combining Streams with CombineLatest

时间:2016-03-11 06:26:12      阅读:153      评论:0      收藏:0      [点我收藏+]

标签:

Two streams often need to work together to produce the values you’ll need. This lesson shows how to use an input stream and an interval stream together and push an object with both values through the stream.

 

const Observable = Rx.Observable;

const startButton = document.querySelector(‘#start‘);
const halfButton = document.querySelector(‘#half‘);
const quarterButton = document.querySelector(‘#quarter‘);
const input = document.querySelector("#input");
const stopButton = document.querySelector(‘#stop‘);
const resetButton = document.querySelector(‘#reset‘);


const data = {count:0};
const inc = (acc)=> ({count: acc.count + 1});
const reset = (acc)=> data;


const start$ = Observable.fromEvent(startButton, ‘click‘);
const half$ = Observable.fromEvent(halfButton, ‘click‘);
const quarter$ = Observable.fromEvent(quarterButton, ‘click‘);
const stop$ = Observable.fromEvent(stopButton, ‘click‘);
const reset$ = Observable.fromEvent(resetButton, ‘click‘);
const starters$ =  Observable.merge(
    start$.mapTo(1000),
    half$.mapTo(500),
    quarter$.mapTo(250)
 );
const intervalActions = (time) => {
      return Observable.merge(
        Observable.interval(time)
        .takeUntil(stop$)
        .mapTo(inc),
        reset$.mapTo(reset)
      )
    };
const timer$ = starters$
 .switchMap(intervalActions)
 .startWith(data)
 .scan( (acc, curr) => curr(acc));
const input$ = Observable.fromEvent(input, "input")
  .map(ev=>ev.target.value);

Observable.combineLatest(
  timer$,
  input$
)
// We will get an array combineLatest
.map((array)=>{
  return {count: array[0].count, input: array[1]}
})
.subscribe(x => console.log(x))

 

They last param of combineLatest is a result function, which can parse the result in the fucntion:

Observable.combineLatest(
  timer$,
  input$,
  (timer, input)=>{
     return {count: timer.count, input}
  }
)
.subscribe(x => console.log(x))

 

[RxJS] Combining Streams with CombineLatest

标签:

原文地址:http://www.cnblogs.com/Answer1215/p/5264169.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!