官术网_书友最值得收藏!

Reusing observables

In the previous section, we saw how we can use operators to create new observables, but until this moment, we have never tried reusing an observable. To do this, I propose a change in the program we created in the previous section. We still want to print the string for every date where the seconds part is an even number. But now, let's also print the string a second has passed every second. To do this, we can use another Bacon.interval call to generate a new observable that emits an empty object every second. Once this is done, we can map each object in the observable to the string we want and finally subscribe to print, as you can see in the following code:

Bacon 
.interval(1000)
.map(
()=> 'a second has passed'
)
.onValue((str)=> console.log(str));

If you add the preceding code to the last program, you will see the following output:

    a second has passed
The number in the second part of the date 2016-11-23T22:42:18.683Z
is 18 which is as even number

a second has passed
a second has passed
The number in the second part of the date 2016-11-23T22:42:20.696Z
is 20 which is as even number

a second has passed
a second has passed
The number in the second part of the date 2016-11-23T22:42:22.702Z
is 22 which is as even number

This solution is okay, but we can reuse the first Bacon.interval(), storing it in a variable. This way, we don't have to keep repeating this code every time we want a source of events emitting every second, using a variable as follows:

var emitsEverySecondStream = Bacon.interval(1000); 

We can create better code by reusing this variable as follows:

var emitsEverySecondStream = Bacon.interval(1000); 
emitsEverySecondStream.map(
(i)=> new Date()
)
.filter(
(date)=>date.getSeconds() % 2 == 0
)
.map(
(date)=> 'The number in the second part of the date ' +
date.toISOString() + ' is ' + date.getSeconds() +
' which is as even number'
)
.onValue((date)=>console.log(date));
emitsEverySecondStream.map(
()=> 'a second has passed'
)
.onValue((str)=> console.log(str));

This code gives us the same kind of output as from the previous example.

Another important feature when reusing observables is the ability to add multiple subscribers to the same observable. You can see this happening in the following code:

var eventStream = Bacon 
.interval(1000)
.map(
()=> 'a second has passed'
);
eventStream
.onValue((str)=>console.log('Subscriber 1 prints => ' + str));
eventStream
.onValue((str)=>console.log('Subscriber 2 prints => ' + str));
eventStream
.onValue((str)=>console.log('Subscriber 3 prints => ' + str));

In this code, we added three subscriptions to the same EventStream. This will give us the following output:

    Subscriber 1 prints => a second has passed
Subscriber 2 prints => a second has passed
Subscriber 3 prints => a second has passed
Subscriber 1 prints => a second has passed
Subscriber 2 prints => a second has passed
Subscriber 3 prints => a second has passed
Remember that the onValue() function returns a function to unsubscribe that function from the observable. So if you want, you can unsubscribe from each subscription individually without affecting other subscriptions.
主站蜘蛛池模板: 镇雄县| 彝良县| 左贡县| 屏山县| 应城市| 肥西县| 高雄市| 清水县| 枣阳市| 平潭县| 丽江市| 鸡泽县| 湖北省| 瑞丽市| 阳曲县| 郴州市| 唐山市| 延安市| 营口市| 什邡市| 岳普湖县| 巴彦县| 上蔡县| 南充市| 额敏县| 顺昌县| 靖安县| 太仓市| 东城区| 巨鹿县| 阿坝| 法库县| 新乡县| 濮阳市| 平和县| 鄂托克前旗| 阿拉善右旗| 西华县| 常州市| 白城市| 越西县|