Angularjs   发布时间:2022-04-20  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了angular – 如何处理可观察到的错误但继续遵循可观察的错误?大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
@H_301_6@ 我有一个observable,http处理其他observable中间.
如果http get响应代码不是200,我想记下这个错误,但继续下一个observable.

到目前为止我有这个:

this.getConfigurationSettings()
    .do(config => {
        console.log('configuration settings.: ',config);
        this.configSettings = config;
        this.subscriptionService.setWSAddressProvider('badUrl');
    })
    .switchMap(config => this.askForWSData())
    .do(config =>
        console.log('askForWSData' + config))
    .switchMap(r => this.processWSData())
    .subscribe(
        config => {
            console.log('start of data processing: ' + config);
        },err => {
            // Log errors if any
            console.log(err);
        },() => console.log('app exiting'));

并且可以返回http错误代码的observable如下:

setWSAddressProvider() : Observable<string[]> {
    return this.http.get('badUrl')
        .map((res:Response) => {
            this.address = res.text();
            return [res.text()];
        });
        // .catch((error:any) =>
        // Observable.throw('Server error')
        // );
}

上述情况产生400响应代码.我想记录该返回但继续其他可观察对象.
怎么做?

解决方法

您可以使用catch来处理 http errors

setWSAddressProvider() : Observable<string[]> {
    return this.http.get('badUrl')
        .map((res:Response) => {
            this.address = res.text();
            return [res.text()];
        });
       .catch((error: Response | any) => {
           if (error instanceof Response) {
                if (error.status === 400) {
                    console.log("Server responded with 400");
                    // Create a new observable with the data for the rest of the chain
                    return Observable.of([]);
                }
           }
           // Re-throw unhandled error
           return Observable.throw(err);
    });

}

大佬总结

以上是大佬教程为你收集整理的angular – 如何处理可观察到的错误但继续遵循可观察的错误?全部内容,希望文章能够帮你解决angular – 如何处理可观察到的错误但继续遵循可观察的错误?所遇到的程序开发问题。

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

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