[RxJS] SampleTime & Sample

SampleTime

If there is no value emiited between sample time and previous emited value, ouput won't have anything.

import { fromEvent, interval } from 'rxjs';
import { sample, sampleTime, map } from 'rxjs/operators';

const click$ = fromEvent(document, 'click');
const timer$ = interval(1000);

click$
  .pipe(
    /*
     * At the duration you specify, sample time will emit the last
     * emitted value within that window. For instance, in this 
     * example we are sampling at an interval of 4s. When the 4s
     * interval timer begins, you can click twice. Once 4s passes,
     * the second click will be emitted. This behavior is then repeated.
     * If no values are emitted from the source in the sample
     * window no values are emitted by sampleTime.
     */
    sampleTime(4000),
    // @ts-ignore
    map(({ clientX, clientY }) => ({
      clientX,
      clientY
    }))
  )
  .subscribe(console.log);

 

Sample

import { fromEvent, interval } from 'rxjs';
import { sample, sampleTime, map } from 'rxjs/operators';

const click$ = fromEvent(document, 'click');
const timer$ = interval(1000);

timer$.pipe(
  /*
   * The sample window can also be based off another stream. 
   * For instance, in this example every time you click the
   * last value emitted by the timer$ observable will be emitted
   * by sample.
   */
  sample(click$)
).subscribe(console.log);

 

 

posted @   Zhentiw  阅读(31)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
历史上的今天:
2021-10-13 [SAP] 37. Snow family
2020-10-13 [Kotlin] Visibilities
2020-10-13 [Kotlin] Getter and Setter
2019-10-13 [Flutter] Router Navigation
2019-10-13 [Flutter] Create a Customer widget
2017-10-13 [React] Compound Component (React.Children.map & React.cloneElement)
2016-10-13 [TypeScript] Creating a Class in TypeScript
点击右上角即可分享
微信分享提示