在@angular-redux/store configureStore 9版本中正确注册epics,需要按照以下步骤进行操作:
NgReduxModule
和EpicMiddleware
:import { NgReduxModule, NgRedux } from '@angular-redux/store';
import { createEpicMiddleware } from 'redux-observable';rootEpic
的根epic。epic是一个接收action流并返回新的action流的函数。可以根据具体需求编写自定义的epic。以下是一个示例:import { ActionsObservable, ofType } from 'redux-observable';
import { mapTo } from 'rxjs/operators';const rootEpic = (action$: ActionsObservable<any>) =>
action$.pipe(
ofType('SOME_ACTION_TYPE'),
mapTo({ type: 'ANOTHER_ACTION_TYPE' })
);
const epicMiddleware = createEpicMiddleware();
@NgModule({
imports: [
NgReduxModule
],
providers: [
{
provide: NgRedux,
useFactory: configureStore,
deps: [epicMiddleware]
},
{
provide: epicMiddleware,
useFactory: createEpicMiddleware,
},
{
provide: rootEpic,
useValue: rootEpic,
}
]
})
export class AppModule { }
export function configureStore(ngRedux: NgRedux<any>, epicMiddleware: EpicMiddleware<any>) {
ngRedux.configureStore(rootReducer, {}, [epicMiddleware]);
epicMiddleware.run(rootEpic);
}
constructor(private ngRedux: NgRedux<any>) {}
someMethod() {
this.ngRedux.dispatch({ type: 'SOME_ACTION_TYPE' });
}
请注意,以上步骤是基于@angular-redux/store 9版本的配置。具体版本可能会有所不同,因此请根据您使用的版本进行相应的调整。
关于@angular-redux/store和redux-observable的更多信息和使用示例,您可以参考腾讯云提供的相关文档和示例代码:
领取专属 10元无门槛券
手把手带您无忧上云