我不是Angular的新手,但我是ngrx的新手。 我正在尝试从服务器中获取一些值,然后将它们简单地打印到屏幕上,我可以看到这些值是从服务器返回的,结果是该效果捕获到了动作并完成了工作:
但是我的简单组件什么都不显示:
ProfileComponent.ts:
export class ProfileComponent implements OnInit {
network$= this.store.select(a=>a.NetworkInfo)
profiles$: Observable<Profile[]> = this.store.select(state => state.Profiles);
constructor(private store:Store<NetAlertState>) { }
ngOnInit() {
this.store.dispatch({ type: '[Profile Component] getAllProfiles' });
this.store.dispatch({ type: '[Profile Component] getNetworkInfo' });
}
}
profile.component.html:
<div *ngFor="let profile of profiles$ | async">
{{ profile.name }}
</div>
net-alert.actions.ts:
export const getAllProfiles = createAction('[Profile Component] getAllProfiles');
export const getNetworkInfo = createAction('[Profile Component] getNetworkInfo');
export const loadProfilesSuccess = createAction('[Profile Component] loadProfilesSuccess',props<{items:Profile[]}>());
export const loadNetworkInfoSuccess = createAction('[Profile Component] loadNetworkInfoSuccess', props<NetworkInfo>());
export const loadProfilesFailure = createAction('[Profile Component] loadProfilesFailure',props<String>());
export const loadNetworkInfoFailure = createAction('[Profile Component] loadNetworkInfoFailure',props<String>());
net-alert.reducer.ts
export const initialState: NetAlertState = {
Profiles:null,
NetworkInfo:null,
isLoading: false,
error: null
}
export const NetAlertReducer = createReducer(
initialState,
on(NetAlertActions.getAllProfiles, state => ({ ...state,isLoading:true ,error:null})),
on(NetAlertActions.loadProfilesSuccess, (state,profiles) => ({ Profiles:profiles,...state ,isLoading:false ,error:null})),
on(NetAlertActions.loadProfilesFailure, (state,err) => ({ ...state,isLoading:false ,error:err})),
on(NetAlertActions.getNetworkInfo, state => ({ ...state ,isLoading:true ,error:null})),
on(NetAlertActions.loadNetworkInfoSuccess, (state,res) => ({ ...state,NetworkInfo:res,isLoading:false ,error:null})),
on(NetAlertActions.loadNetworkInfoFailure, (state,err) => ({ ...state,isLoading:false ,error:err})),
);
export function reducer(state: NetAlertState | undefined, action: Action) {
return NetAlertReducer(state, action);
}
net-alert.effects.ts:
@Injectable()
export class NetAlertEffects {
loadProfiles$ = createEffect(() =>
this.actions$.pipe(
ofType('[Profile Component] getAllProfiles'),
mergeMap(() => this.dataService.getAllProfiles()
.pipe(
map(res => ({ type: '[Profile Component] loadProfilesSuccess', payload: res })),
catchError(() => of({ type: '[Profile Component] loadProfilesFailure' }))
)
)
)
);
constructor(
private actions$: Actions,
private dataService: DataService
) {}
}
net-alert.state.ts:
export interface NetAlertState {
isLoading: boolean;
error: any;
NetworkInfo: NetworkInfo;
Profiles: Profile[];
}
export interface Profile {
Mac: string;
NickName: string;
CreateDate: Date;
Sites?: any;
}
root-state.ts:
export interface AppStates {
netAlert: NetAlertState;
}
export const netAlertReducers: ActionReducerMap<AppStates> = {
netAlert: netAlertRerucers.reducer
};
app.module.ts:
@NgModule({
declarations: [
AppComponent,
ProfileContainerComponent,
ProfileComponent
],
imports: [
HttpClientModule,
BrowserModule,
AppRoutingModule,
StoreModule.forRoot(netAlertReducers),
EffectsModule.forRoot([NetAlertEffects]),
StoreDevtoolsModule.instrument({
maxAge: 25, // Retains last 25 states
logOnly: environment.production, // Restrict extension to log-only mode
}),
RootStoreModule
],
providers: [],
bootstrap: [AppComponent]
})
export class AppModule { }
有人可以告诉我我的错误在哪里吗?
非常感谢!
答案 0 :(得分:1)
如果您没有减速器通过loadProfilesSuccess
操作更新状态,则它将无法正常工作。像这样:
const myReducer = createReducer(
initialState, // type NetAlertState
on(from.loadProfilesSuccess, (state, action) => {
// return new state from action payload
}),
)
export function reducer(state: NetAlertState, action: Action) {
return myReducer(state, action);
}
您有操作,但也从未使用过。您应该在任何地方使用它们:
ngOnInit() {
this.store.dispatch(getAllProfiles());
this.store.dispatch(getNetworkInfo());
}
loadProfiles$ = createEffect(() =>
this.actions$.pipe(
ofType(getAllProfiles),
mergeMap(() => this.dataService.getAllProfiles()
.pipe(
map(res => loadProfilesSuccess(res)),
catchError(() => of(loadProfilesFailure())
)
)
)
);
答案 1 :(得分:1)
我看不到用于选择“ netAlert”状态的选择器,您可以在其上构建其他选择器,如下所示:
selectors.ts
.fork
component.ts
import * as fromNetAlertState from "./state";
export const netAlertState = (state: State) => state.netAlert;
export const selectProfiles = createSelector(
netAlertState,
(state: fromNetAlertState.State) => state.Profiles
);
答案 2 :(得分:0)
您应该像这样将您的配置文件$放入ngOnInit方法
export class ProfileComponent implements OnInit {
network$: any;
profiles$: Observable<Profile[]>
constructor(private store:Store<NetAlertState>) { }
ngOnInit() {
this.store.dispatch({ type: '[Profile Component] getAllProfiles' });
this.store.dispatch({ type: '[Profile Component] getNetworkInfo' });
this.network$ = this.store.select(a=>a.NetworkInfo);
this.profiles$ = this.store.pipe(select(state => state.Profiles));
}
}
也尝试使用管道运算符