Angular:如何从http请求列表中返回第一个成功的响应?
创始人
2024-11-01 23:00:36
0

可以使用RxJS中的race操作符来实现。race操作符接收一组Observable,并只返回第一个发出成功响应的Observable。

以下是代码示例:

import { Observable } from 'rxjs'; import { mapTo, map } from 'rxjs/operators'; import { HttpClient } from '@angular/common/http';

// 假设这是一组http请求Observable const requestOne$ = this.http.get('https://api.example.com/requestOne'); const requestTwo$ = this.http.get('https://api.example.com/requestTwo'); const requestThree$ = this.http.get('https://api.example.com/requestThree');

// race操作符只返回第一个成功响应的Observable const successfulRequest$ = race( requestOne$.pipe(mapTo('requestOne')), requestTwo$.pipe(mapTo('requestTwo')), requestThree$.pipe(mapTo('requestThree')) ).pipe( map((result: string) => { console.log(Request ${result} successful.); return result; }) );

// 订阅成功的Observable successfulRequest$.subscribe();


在该示例中,使用了HttpClient发送三个http请求,然后使用race操作符将三个请求的Observable传递给它,并只返回第一个成功响应的Observable。在成功响应的Observable上,可以选择使用map操作符获取关于哪个请求成功的信息。最后,订阅成功的Observable以执行任何后续操作。

相关内容

热门资讯

透视解密"wepok... 透视解密"wepoker有透视功能吗"本来是有辅助攻略(哔哩哔哩)wepoker有透视功能吗脚本下载...
透视必备"wepok... 透视必备"wepoker私人局透视插件"一直是有辅助攻略(哔哩哔哩)1、wepoker私人局透视插件...
透视普及"哈糖大菠萝... 透视普及"哈糖大菠萝免费辅助器"总是真的是有辅助神器(哔哩哔哩)1、该软件可以轻松地帮助玩家将哈糖大...
透视推荐"竞技联盟辅... 透视推荐"竞技联盟辅助插件"好像真的是有辅助挂(哔哩哔哩)1、任何竞技联盟辅助插件透视是真的假的的玩...
透视关于"hhpok... 透视关于"hhpoker万能辅助器"切实是真的辅助攻略(哔哩哔哩)hhpoker万能辅助器脚本下载中...
透视详细"wpk模拟... 透视详细"wpk模拟器是什么"其实存在有辅助神器(哔哩哔哩)1、完成wpk模拟器是什么有辅助插件,帮...
透视解密"hhpok... 透视解密"hhpoker真能买到挂吗"竟然是有辅助挂(哔哩哔哩)1、下载好hhpoker真能买到挂吗...
透视专业"红龙pok... 透视专业"红龙poker辅助平台"好像存在有辅助软件(哔哩哔哩)暗藏猫腻,小编详细说明红龙poker...
透视曝光"福建大菠萝... 透视曝光"福建大菠萝万能辅助器"果然有辅助攻略(哔哩哔哩)1、玩家可以在福建大菠萝万能辅助器线上大神...
透视解密"wepok... 透视解密"wepoker买钻石有用吗"一直真的有辅助app(哔哩哔哩)1、玩家可以在wepoker买...