Angular NGRX多个存储
创始人
2024-10-20 09:01:13
0

在Angular中,可以使用NGRX进行状态管理,并且可以使用多个存储来管理不同的模块或部分应用程序的状态。下面是一个解决方案的示例代码。

首先,安装必要的依赖项:

npm install @ngrx/store
npm install @ngrx/effects
npm install @ngrx/entity

然后,创建每个模块或部分应用程序的存储。

例如,假设我们有一个用户模块和一个订单模块,我们可以创建以下存储:

  1. 用户存储:
// user.actions.ts
import { createAction } from '@ngrx/store';

export const setUser = createAction('[User] Set User');

// user.reducer.ts
import { createReducer, on } from '@ngrx/store';
import { setUser } from './user.actions';

export interface UserState {
  user: any;
}

export const initialState: UserState = {
  user: null,
};

export const userReducer = createReducer(
  initialState,
  on(setUser, (state, { user }) => ({ ...state, user }))
);

// user.selectors.ts
import { createSelector } from '@ngrx/store';
import { UserState } from './user.reducer';

export const selectUserState = (state: any) => state.user;

export const selectUser = createSelector(
  selectUserState,
  (state: UserState) => state.user
);
  1. 订单存储:
// order.actions.ts
import { createAction } from '@ngrx/store';

export const setOrder = createAction('[Order] Set Order');

// order.reducer.ts
import { createReducer, on } from '@ngrx/store';
import { setOrder } from './order.actions';

export interface OrderState {
  order: any;
}

export const initialState: OrderState = {
  order: null,
};

export const orderReducer = createReducer(
  initialState,
  on(setOrder, (state, { order }) => ({ ...state, order }))
);

// order.selectors.ts
import { createSelector } from '@ngrx/store';
import { OrderState } from './order.reducer';

export const selectOrderState = (state: any) => state.order;

export const selectOrder = createSelector(
  selectOrderState,
  (state: OrderState) => state.order
);

接下来,将存储添加到应用程序的根存储中。

// app.module.ts
import { StoreModule } from '@ngrx/store';
import { EffectsModule } from '@ngrx/effects';
import { userReducer } from './user/user.reducer';
import { orderReducer } from './order/order.reducer';

@NgModule({
  imports: [
    StoreModule.forRoot({
      user: userReducer,
      order: orderReducer,
    }),
    EffectsModule.forRoot([]),
    // ...
  ],
  // ...
})
export class AppModule {}

最后,您可以在组件中使用这些存储。

// user.component.ts
import { Component, OnInit } from '@angular/core';
import { Store } from '@ngrx/store';
import { setUser } from './user.actions';
import { selectUser } from './user.selectors';

@Component({
  selector: 'app-user',
  template: `
    
User: {{ user$ | async }}
`, }) export class UserComponent implements OnInit { user$ = this.store.select(selectUser); constructor(private store: Store) {} ngOnInit() {} setUser() { this.store.dispatch(setUser({ user: 'John Doe' })); } }
// order.component.ts
import { Component, OnInit } from '@angular/core';
import { Store } from '@ngrx/store';
import { setOrder } from './order.actions';
import { selectOrder } from './order.selectors';

@Component({
  selector: 'app-order',
  template: `
    
Order: {{ order$ | async }}
`, }) export class OrderComponent implements OnInit { order$ = this.store.select(selectOrder); constructor(private store: Store) {} ngOnInit() {} setOrder() { this.store.dispatch(setOrder({ order: '123' })); } }

以上是一个基本的示例,展示了如何在Angular中使用NGRX的多个存储来管理不同部分的状态。您可以根据实际需求进行调整和扩展。

相关内容

热门资讯

科普攻略!德普之星辅助器app... 科普攻略!德普之星辅助器app,we poker辅助器,德州论坛(有挂软件)是一款可以让一直输的玩家...
重大科普!佛手在线大菠萝智能辅... 重大科普!佛手在线大菠萝智能辅助器,wepoker作弊辅助,分享教程(有挂软件);原来确实真的有挂(...
一分钟教会你!wepoker怎... 一分钟教会你!wepoker怎么增加运气,epoker透视,切实教程(有挂透视)1、点击下载安装,微...
六分钟了解!hhpoker有辅... 六分钟了解!hhpoker有辅助吗,wepoker国外版透视,扑克教程(有挂技巧)科技教程也叫必备教...
我来教大家!wepoker辅助... 我来教大家!wepoker辅助透视,wepoker免费脚本弱密码,详细教程(有挂透明);wepoke...
记者发布!wpk辅助,德普之星... 记者发布!wpk辅助,德普之星透视辅助软件激活码,解密教程(有挂辅助);亲真的是有正版授权,小编(透...
揭秘攻略!aapoker万能辅... 《揭秘攻略!aapoker万能辅助器,hhpoker真的假的,揭秘教程(有挂教程)》 aapoker...
重大通报!sohoo poke... 自定义sohoo poker辅助器系统规律,只需要输入自己想要的开挂功能,一键便可以生成出微扑克专用...
三分钟了解!wpk辅助器,hh... 1、三分钟了解!wpk辅助器,hhpoker免费辅助器,必赢教程(有挂神器);详细教程。2、hhpo...
玩家必看攻略!wejoker私... 玩家必看攻略!wejoker私人辅助软件,智星德州可以透视吗,透明挂教程(有挂技巧)关于智星德州可以...