gpt4 book ai didi

angular - 如何发出 Observable 然后限制订阅

转载 作者:太空狗 更新时间:2023-10-29 17:38:46 24 4
gpt4 key购买 nike

在 RxJS 中,auditTimethrottleTime 等过滤器会在经过一定时间后发出一个 Observable(以不同的方式)。我需要发射一个 Observable,然后然后在发射下一个值之前等待一段时间。

就我而言,我在 Angular 工作。例如,这段代码:

this.fooService$.pipe(throttleTime(10000)).subscribe(() => this.doSomething());

不会完成我需要的,因为发射发生在持续时间结束时。我需要相反的东西:发射发生然后延迟。我怎样才能做到这一点?

最佳答案

使用经典的超时函数怎么样?

this.fooService$.subscribe( () =>
setTimeout(() => { this.doSomething(); }, 3000)
);

编辑:

引用您的评论,在您的发射端执行以下操作(仅作为示例):

// RxJS v6+
import { timer, BehaviorSubject } from 'rxjs';

// timer starts with a delay of 1000 ms and then emits every 2000 ms
const source = timer(1000, 2000);
const emitter: BehaviorSubject<number> = new BehaviorSubject(-1);

const subscribe = source.subscribe( value => this.emitter.next(value));

关于angular - 如何发出 Observable 然后限制订阅,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54395824/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com