AngularngRxDispatchSecondActionwithdatafromFirstAction的中文描述
创始人
2024-10-28 18:00:31
0

Angular 中的 ngRx 库提供了一种处理应用程序状态的强大机制。当我们需要在第一个 Action 执行完毕后,将其产生的数据传递给第二个 Action 时,可以通过使用 RxJS 操作符来实现。下面是一个示例代码,展示了如何使用 combineLatest 操作符来完成这个任务:

import { Actions, ofType } from '@ngrx/effects';
import { Injectable } from '@angular/core';
import { Action } from '@ngrx/store';
import { Observable, combineLatest } from 'rxjs';
import { map, switchMap } from 'rxjs/operators';

@Injectable()
export class MyEffects {
  constructor(private actions$: Actions) {}

  // 第一个 Action
  firstAction$: Observable = this.actions$.pipe(
    ofType('FIRST_ACTION_TYPE'),
    map((action: any) => action.payload)
  );

  // 第二个 Action
  secondAction$: Observable = combineLatest(
    this.actions$.pipe(ofType('FIRST_ACTION_TYPE')),
    this.someOtherService.getData() // 获取第一步数据,并传递给第二个Action
  ).pipe(
    switchMap(([action, data]) => {
       // 在这里操作第二个 Action
    })
  );
}

在上面的代码中,通过使用 combineLatest 操作符,我们在第一个 Action 完成后,调用了第二个 Action,并将第一个 Action 产生的数据传递给后者。由于 combineLatest 操作符会将所有流中最后发出的值作为参数传递给其回调函数,因此我们可以在它的回调函数中访问这个数据,并在其中操作第二个 Action。

相关内容

热门资讯

记者发布!wpk辅助,德普之星... 记者发布!wpk辅助,德普之星透视辅助软件激活码,解密教程(有挂辅助);亲真的是有正版授权,小编(透...
揭秘攻略!aapoker万能辅... 《揭秘攻略!aapoker万能辅助器,hhpoker真的假的,揭秘教程(有挂教程)》 aapoker...
重大通报!sohoo poke... 自定义sohoo poker辅助器系统规律,只需要输入自己想要的开挂功能,一键便可以生成出微扑克专用...
三分钟了解!wpk辅助器,hh... 1、三分钟了解!wpk辅助器,hhpoker免费辅助器,必赢教程(有挂神器);详细教程。2、hhpo...
玩家必看攻略!wejoker私... 玩家必看攻略!wejoker私人辅助软件,智星德州可以透视吗,透明挂教程(有挂技巧)关于智星德州可以...
程序员教你!hh poker透... 程序员教你!hh poker透视器下载,hhpoker的辅助是真的吗,必胜教程(有挂教程);致您一封...
科普攻略!aapoker怎么选... 科普攻略!aapoker怎么选牌,wepoker辅助器激活码,透明挂教程(有挂软件);亲真的是有正版...
玩家必备教程!德州透视插件,w... 这是一款非常优秀的wejoker黑侠辅助器 ia辅助检测软件,能够让你了解到wejoker黑侠辅助器...
记者揭秘!wepoker私局代... 记者揭秘!wepoker私局代打,安装不了wepoker,安装教程(有挂攻略)准备好在wepoker...
教学盘点!德普之星透视,hhp... 教学盘点!德普之星透视,hhpoker到底可以作弊码,新2025教程(有挂技巧);hhpoker到底...