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

相关内容

热门资讯

七分钟辅助!丽水茶苑苹果手机辅... 七分钟辅助!丽水茶苑苹果手机辅助,本来是真的有辅助教程(有挂方式)1、实时丽水茶苑苹果手机辅助透视辅...
第一分钟辅助!闲来辅助神器下载... 第一分钟辅助!闲来辅助神器下载2022,好像真的有辅助方法(有挂教程)1、不需要AI权限,帮助你快速...
九分钟辅助!丽水都莱辅助工具试... 九分钟辅助!丽水都莱辅助工具试用,确实存在有辅助神器(有挂方法)九分钟辅助!丽水都莱辅助工具试用,确...
第一分钟辅助!蛮王辅助器,好像... 第一分钟辅助!蛮王辅助器,好像是有辅助方法(有挂教学)1、首先打开蛮王辅助器辅助器下载最新版本,在蛮...
第六分钟辅助!潮汕汇挂,一贯真... 第六分钟辅助!潮汕汇挂,一贯真的是有辅助插件(有挂辅助)1、这是跨平台的潮汕汇挂轻量版有透视,在线的...
六分钟辅助!微信开心泉州辅助器... 六分钟辅助!微信开心泉州辅助器,一直有辅助器(有挂教学)1、下载好微信开心泉州辅助器透视辅助下载之后...
第3分钟辅助!佛手十三道破解版... 第3分钟辅助!佛手十三道破解版安卓,竟然真的有辅助攻略(有挂存在)1、让任何用户在无需佛手十三道破解...
2分钟辅助!sohoo竞技联盟... 2分钟辅助!sohoo竞技联盟辅助,切实真的有辅助脚本(有挂技术)1.sohoo竞技联盟辅助 选牌创...
第8分钟辅助!心悦手游辅助器,... 第8分钟辅助!心悦手游辅助器,原来真的是有辅助技巧(确实有挂);1、每一步都需要思考,不同水平的挑战...
第十分钟辅助!广东雀神祈福真的... 第十分钟辅助!广东雀神祈福真的有用吗,都是是有辅助技巧(有挂方略)1、下载好广东雀神祈福真的有用吗透...