Angular NGRX多个存储
创始人
2024-10-20 09:02:30
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的多个存储来管理不同部分的状态。您可以根据实际需求进行调整和扩展。

相关内容

热门资讯

Android Recycle... 要在Android RecyclerView中实现滑动卡片效果,可以按照以下步骤进行操作:首先,在项...
安装apache-beam==... 出现此错误可能是因为用户的Python版本太低,而apache-beam==2.34.0需要更高的P...
Android - 无法确定任... 这个错误通常发生在Android项目中,表示编译Debug版本的Java代码时出现了依赖关系问题。下...
Android - NDK 预... 在Android NDK的构建过程中,LOCAL_SRC_FILES只能包含一个项目。如果需要在ND...
Akka生成Actor问题 在Akka框架中,可以使用ActorSystem对象生成Actor。但是,当我们在Actor类中尝试...
Agora-RTC-React... 出现这个错误原因是因为在 React 组件中使用,import AgoraRTC from “ago...
Alertmanager在pr... 首先,在Prometheus配置文件中,确保Alertmanager URL已正确配置。例如:ale...
Aksnginxdomainb... 在AKS集群中,可以使用Nginx代理服务器实现根据域名进行路由。以下是具体步骤:部署Nginx i...
AddSingleton在.N... 在C#中创建Singleton对象通常是通过私有构造函数和静态属性来实现,例如:public cla...
Alertmanager中的基... Alertmanager中可以使用repeat_interval选项指定在一个告警重复发送前必须等待...