Angularjs   发布时间:2022-04-20  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了Angular 4中的长轮询大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我需要做API调用显示某些内容的进度.

我创建了一个服务,每1.5秒执行一次

主要部分

private getProgress() {
        this.progressservice.getExportProgress(this.type,this.details.requestID);
    }

services.ts

public getExportProgress(type: String,requestId: String) {
    Observable.interval(1500)
        .switchMap(() => this.http.get(this.apiEndpoint + "DeFinition/" + type + "/Progress/" + requestId))
        .map((data) => data.json().Data)
        .subscribe(
        (data) => {
            if (!data.InProgress)
                //Stop doing this api call
        },error => this.handleError(error));
}

这个电话有效,但它一直在继续.我想在进度结束时停止进行API调用(if(!data.InProgress)但是我坚持这一点.

如果if(!data.InProgress),我怎样才能正确取消订阅此observable?

谢谢

解决方法

您可以使用takeWhile运算符.

这是文档:
http://reactivex.io/rxjs/class/es6/Observable.js~Observable.html#instance-method-takeWhile

这是一个通用的例子:
https://rxviz.com/v/yOE6Z5JA

Rx.observable
  .interval(100)
  .takeWhile(x => x < 10)
  .subscribe(x => { console.log(X); });

以下是您的代码例:

public getExportProgress(type: String,requestId: String) {
    Observable.interval(1500)
        .switchMap(() => this.http.get(this.apiEndpoint + "DeFinition/" + type + "/Progress/" + requestId))
        .map((data) => data.json().Data)
        .takeWhile((data) => data.InProgress)
        .subscribe(
        (data) => {
            ...
        },error => this.handleError(error));
}

大佬总结

以上是大佬教程为你收集整理的Angular 4中的长轮询全部内容,希望文章能够帮你解决Angular 4中的长轮询所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。