[RxJS] Transformation operator: bufferToggle, bufferWhen
2024-09-04 23:52:15
bufferToggle(open: Observable, () => close: Observalbe : Observalbe<T[]>)
bufferToggle take two args, first is opening observable, seconde is a function which return an observable for closing.
The closeing observalbe only execute after opening emit value.
const source$ = Rx.Observable.interval(500);
const open$ = Rx.Observable.interval(1500);
const close$ = Rx.Observable.interval(1000); /** ---0---1---2---3---4---5---6---7---8---9----.... (source) -----------1-----------2-----------3--------... (open) --- ---x --- ---x --- ---x... (close)
bufferToggle(open$, () => close$) ------------------([2,3])-----([5.6])-----([8,9])--...
*/ const foo$ = source$.bufferToggle(open$, () => {
return close$;
}); foo$.subscribe(
(x) => console.debug("Next: " + x),
(err) => console.error(err),
() => console.info("DONE")
) /* "Next: 2,3"
"Next: 5,6"
"Next: 8,9"
"Next: 11,12"
...
*/
bufferWhen( () => Observable):
bufferWhen takes a function which return observable.
const source$ = Rx.Observable.interval(500);
const close$ = Rx.Observable.interval(1000); /** ---0---1---2---3---4---5---6---7---8---9----.... (source) -------0-------1-------2-------3-------4---.... (close) bufferWhen(()=>close$) -------(0)-----([1,2])-([3,4])-([5,6])--......
*/ const foo$ = source$.bufferWhen(() => close$); foo$.subscribe(
(x) => console.debug("Next: " + x),
(err) => console.error(err),
() => console.info("DONE")
) /* "Next: 0"
"Next: 1,2"
"Next: 3,4"
"Next: 5,6"
"Next: 7,8"
...
*/
最新文章
- C++11 shared_ptr 智能指针 的使用,避免内存泄露
- NK3C程序配置
- 【POJ】3398 Perfect Service
- JavaScript 各种遍历方式详解,有你不知道的黑科技
- LeetCode Contains Duplicate II (判断重复元素)
- LeetCode: divideInteger
- WebChat 清爽来袭 -- JavaChat系统Ⅳ
- password学3——Java BASE64加密解密
- 聊天工具mychat
- 单尺度二维离散小波分解dwt2
- Socket的应用案例
- 弹性盒模型 flex box
- Andrew Ng机器学习课程笔记--week5(上)
- Python实现XML文件解析
- yum仓库详细解读
- ArcGis安装失败提示“需要Microsoft .NET Framework 3.5 sp1或等效环境”的解决方法
- 浅谈pc和移动端的响应式
- mdf ldf添加到数据库
- .Net MVC 当前上下文中不存在名称“Style”
- PostgreSQL源码安装文档