AngularNgrx-在dispatch操作时,Effects没有被调用。
创始人
2024-10-28 17:01:19
0

这可能是由于在dispatch前未注入Effect源或在提供程序中未正确声明导致的。以下是一个示例:

在您的模块中引入Effects和Store模块:

import { EffectsModule } from '@ngrx/effects'; import { StoreModule } from '@ngrx/store';

@NgModule({ imports: [ StoreModule.forRoot({}), EffectsModule.forRoot([]), ... ], ... })

在您的组件或服务文件中,创建一个action并使用dispatch将其发送到store:

import { MyAction } from '../store/my-action.actions'; import { Store } from '@ngrx/store';

constructor(private store: Store) {}

triggerAction() { this.store.dispatch(new MyAction()); }

在您的Effect中,监听您的Action并执行所需的操作:

import { Injectable } from '@angular/core'; import { Actions, Effect, ofType } from '@ngrx/effects'; import { MyAction } from '../store/my-action.actions'; import { tap } from 'rxjs/operators';

@Injectable() export class MyEffect { @Effect({dispatch: false}) myAction$ = this.actions$.pipe( ofType(MyAction), tap(() => console.log('MyAction was dispatched!')) );

constructor(private actions$: Actions) {}

}

确认在提供程序中正确声明effect:

import { EffectsModule } from '@ngrx/effects'; import { MyEffect } from './my-effect.effects';

@NgModule({ imports: [ ... EffectsModule.forFeature([MyEffect]), ... ], declarations: [...], providers: [ MyEffect, ... ] })

这些步骤应该能够使Effects在dispatch操作时被正确调用。

相关内容

热门资讯

代打辅助挂!cloudpoke... 代打辅助挂!cloudpoker外开挂,微信小程序游戏辅助,攻略辅助插件(有挂技巧)-哔哩哔哩代打辅...
日前!广东潮汕雀友会插件(辅助... 日前!广东潮汕雀友会插件(辅助)一直真的有辅助平台(讲解有挂)-哔哩哔哩1、下载好广东潮汕雀友会插件...
透视免费!cloudpoker... 透视免费!cloudpoker怎么开挂,创思维透视辅助器,方案辅助软件(有挂方针)-哔哩哔哩1、首先...
长期以来!互游辅助518(辅助... 长期以来!互游辅助518(辅助)切实真的是有辅助下载(有挂助手)-哔哩哔哩1、每一步都需要思考,不同...
这一问题亟待解决!pokerw... 这一问题亟待解决!pokerworld辅助器,大唐开局自动外g挂,攻略辅助攻略(详细教程)-哔哩哔哩...
近日!新西部微信辅助(辅助)一... 近日!新西部微信辅助(辅助)一贯有挂辅助下载(有挂教学)-哔哩哔哩1、打开软件启动之后找到中间准星的...
一直以来!epoker底牌透视... 一直以来!epoker底牌透视,微乐a3纸牌有脚本,法子辅助挂(有挂技术)-哔哩哔哩1、首先打开微乐...
昨日!决战血流辅助器(辅助)切... 昨日!决战血流辅助器(辅助)切实真的是有辅助软件(有挂技术)-哔哩哔哩1、决战血流辅助器免费脚本咨询...
透视辅助!线上德州的辅助器是什... 透视辅助!线上德州的辅助器是什么,越乡游义乌辅助器微信,烘培辅助器(有挂解密)-哔哩哔哩该软件可以轻...
为了进一步!阿拉游戏中心辅助工... 为了进一步!阿拉游戏中心辅助工具(辅助)确实真的是有辅助下载(有挂方式)-哔哩哔哩阿拉游戏中心辅助工...