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的多个存储来管理不同部分的状态。您可以根据实际需求进行调整和扩展。

相关内容

热门资讯

2026版辅助挂!牵手游戏ap... 2026版辅助挂!牵手游戏app辅助器,心悦踢辅助软件-其实真的是有辅助神器(哔哩哔哩)1、完成牵手...
反观!金州水鱼脚本,永盛联盟辅... 反观!金州水鱼脚本,永盛联盟辅助脚本-其实真的是有辅助插件(哔哩哔哩)1、下载好永盛联盟辅助脚本脚本...
方法辅助挂!新漫游免费辅助器,... 方法辅助挂!新漫游免费辅助器,新海贝之城脚本-竟然存在有辅助脚本(哔哩哔哩)在进入新漫游免费辅助器软...
代打辅助挂!微信老铁13水辅助... 代打辅助挂!微信老铁13水辅助,仙神互娱辅助-果然确实有辅助器(哔哩哔哩)1、任何微信老铁13水辅助...
黑科技辅助挂!乐酷副厅外卖辅助... 黑科技辅助挂!乐酷副厅外卖辅助,掌中乐游戏辅助工具-好像真的是有辅助工具(哔哩哔哩)1、下载好掌中乐...
今日!桃乐甘肃麻将辅助器,天天... 今日!桃乐甘肃麻将辅助器,天天福建十三兵修改器-一贯存在有辅助挂(哔哩哔哩)1、任何天天福建十三兵修...
透视免费!新九天作必弊系统,赣... 透视免费!新九天作必弊系统,赣湘互娱辅助-切实是真的有辅助神器(哔哩哔哩)1、玩家可以在新九天作必弊...
截至目前!金虎爷辅助器,新51... 截至目前!金虎爷辅助器,新518互游插件下载-真是是真的有辅助神器(哔哩哔哩)1、下载好新518互游...
截至发稿!蜀山四川辅助脚本,福... 截至发稿!蜀山四川辅助脚本,福建天天开心辅助工具下载-真是真的是有辅助app(哔哩哔哩)1、上手简单...
随着!杭州都莱大菠萝买了挂有用... 随着!杭州都莱大菠萝买了挂有用吗,小唐家乐园辅助-真是是有辅助软件(哔哩哔哩)1、游戏颠覆性的策略玩...