Angular: 如何使一个在 for 循环中的订阅等待直到它完成
创始人
2024-10-22 22:30:04
0

在Angular中,可以使用forkJoin操作符来等待一个在循环中的订阅完成。forkJoin操作符接收一个Observable数组,并在所有的Observables都完成后发出一个数组。

下面是一个示例代码:

import { Component } from '@angular/core';
import { Observable, forkJoin } from 'rxjs';

@Component({
  selector: 'app-root',
  template: `
    
{{ item }}
`, }) export class AppComponent { items: number[] = [1, 2, 3, 4, 5]; start() { const observables: Observable[] = []; this.items.forEach(item => { observables.push(this.someAsyncOperation(item)); }); forkJoin(observables).subscribe(results => { console.log('All operations completed'); // 在这里,可以处理所有操作完成后的逻辑 }); } someAsyncOperation(item: number): Observable { // 模拟一个异步操作,例如HTTP请求 return new Observable(observer => { setTimeout(() => { console.log(`Operation ${item} completed`); observer.next(); observer.complete(); }, Math.random() * 2000); }); } }

在上面的示例中,start方法创建一个Observable数组,并将每个异步操作的Observable添加到数组中。然后,使用forkJoin操作符等待所有的Observables完成。当所有的Observables都完成后,forkJoin会发出一个结果数组,可以在subscribe方法中处理这个结果数组。

someAsyncOperation方法中,模拟了一个异步操作。在实际应用中,你可以替换为真实的异步操作,例如发起一个HTTP请求。

当点击Start按钮时,会依次执行每个异步操作,并在所有操作完成后打印"All operations completed"。

相关内容

热门资讯

9分钟指南书!九天大厅挂价格,... 9分钟指南书!九天大厅挂价格,新祥心辅助脚本(辅助)一贯真的是有辅助(哔哩哔哩)一、新祥心辅助脚本可...
第十分钟窍要!杭麻圈辅助工具,... 第十分钟窍要!杭麻圈辅助工具,天酷游戏交易平台(辅助)原来是有辅助(哔哩哔哩)1、完成天酷游戏交易平...
第六分钟举措!四川游戏家园手机... 第六分钟举措!四川游戏家园手机版辅助,三哥玩app辅助(辅助)果然有挂下载(哔哩哔哩)1、金币登录送...
第八分钟攻略!金州水鱼脚本,新... 第八分钟攻略!金州水鱼脚本,新九五有没有脚本(辅助)果然有挂软件(哔哩哔哩)1、让任何用户在无需新九...
第六分钟秘籍!天天川南辅助,超... 第六分钟秘籍!天天川南辅助,超级三加一辅助工具(辅助)果然是真的安装(哔哩哔哩)1、超级三加一辅助工...
第七分钟教程书!拼三张辅助器,... 第七分钟教程书!拼三张辅助器,海贝之城辅助软甲下载(辅助)原来真的有平台(哔哩哔哩)1、用户打开应用...
第五分钟指引!蜀渝牌乐汇挂机软... 第五分钟指引!蜀渝牌乐汇挂机软件,天酷辅助巡查系统(辅助)果然真的是有安装(哔哩哔哩)该软件可以轻松...
8分钟讲义!微友辅助器免费版v... 8分钟讲义!微友辅助器免费版v2.0,新财神正版辅助挂(辅助)真是真的是有辅助器(哔哩哔哩)1、8分...
8分钟策略!椰岛长胜辅助,随意... 8分钟策略!椰岛长胜辅助,随意玩聚乐部辅助(辅助)本来是有插件(哔哩哔哩)1、该软件可以轻松地帮助玩...
2分钟课程!陕麻圈是不是可以作... 2分钟课程!陕麻圈是不是可以作必弊,蜜蜂大厅辅助插件(辅助)一直真的是有软件(哔哩哔哩)1)陕麻圈是...