首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >角- Ngrx实体收集服务基-序列化

角- Ngrx实体收集服务基-序列化
EN

Stack Overflow用户
提问于 2021-08-13 17:32:21
回答 1查看 363关注 0票数 1

在我当前的项目中,我有一个带有nestjs的后端和一个以角表示的前端。

我正在使用ngrx实体从服务的后端加载一些数据,如下所示:

calendar-event.service.ts

代码语言:javascript
复制
@Injectable({
  providedIn: 'root'
})
export class CalendarEventService extends EntityCollectionServiceBase<CalendarEvent> {

  constructor(elementsFactory: EntityCollectionServiceElementsFactory) {
    super('CalendarEvent', elementsFactory);
  }
}

我有我的实体元数据设置

代码语言:javascript
复制
import {
  EntityMetadataMap,
  EntityDataModuleConfig,
  DefaultDataServiceConfig,
} from '@ngrx/data';

const entityMetadata: EntityMetadataMap = {
  CalendarEvent: {},
};

const pluralNames = {};

export const entityConfig: EntityDataModuleConfig = {
  entityMetadata,
  pluralNames,
};

export const defaultDataServiceConfig: DefaultDataServiceConfig = {
  entityHttpResourceUrls: {
    CalendarEvent: {
      collectionResourceUrl: 'http://localhost:3000/api/calendar/',
      entityResourceUrl: 'http://localhost:3000/api/calendar/',
    },
  },
};

当我从app.component.ts加载数据时,数据加载得很好

代码语言:javascript
复制
import { Observable } from 'rxjs';
import { Component, OnInit } from '@angular/core';
import { CalendarEventService } from './shared/services/calendar-event.service';
import { CalendarEvent } from 'angular-calendar';

@Component({
  selector: 'app-root',
  template: `
    <app-shell class="app-shell">
      <router-outlet></router-outlet>
    </app-shell>
  `,
})
export class AppComponent implements OnInit {
  title = 'memento-front';
  events$: Observable<CalendarEvent[] | any>;

  constructor(private readonly events: CalendarEventService) {
    this.events$ = this.events.filteredEntities$;
  }

  ngOnInit(): void {
    this.events.load();
  }
}

我看到他们很好:

代码语言:javascript
复制
{ "id": 2, "title": "Second event", "start": "2021-08-13T17:22:43.192Z", "color": { "primary": "#1e90ff", "secondary": "#D1E8FF" } }

我试图实现的是当数据被序列化时,而不是给出开始字符串日期,创建一个date对象。这个想法会做一些类似于

代码语言:javascript
复制
const entityMetadata: EntityMetadataMap = {
  CalendarEvent: {
    filterFn: (events) => {
      events.map(event => event.start = new Date(event.start));
      return events;
    }
  },
};

但不是在调用filterFn时执行,而是在http调用变得不可变之前执行。

我试图使用ngrx实体集合服务库查找序列化,但没有发现任何东西让我知道如何在从http调用加载数据属性时采取一些操作。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-08-24 10:36:57

我试图使用ngrx实体集合服务库查找序列化,但没有发现任何东西让我知道如何在从http调用加载数据属性时对数据属性采取一些操作

您可以遵循以下步骤,以便在api调用时对数据属性执行操作:

app.component.ts

代码语言:javascript
复制
this.events$ = store.select(selectAllEvents);
this.eventsService.load().subscribe(events => {      
  this.store.dispatch(EventsApiActions.evensLoaded({ events }));
});

app/events/actions/events-api.actions.ts

代码语言:javascript
复制
export const eventsLoaded = createAction(
    "[Events API] Events Loaded Success",
    props<{ events: CalendarEvent[] }>()
);

app/shared/state/events.reducer.ts

代码语言:javascript
复制
export interface State {
  collection: CalendarEvent[];
  ...
}

export const initialState: State = {
    collection: [],
    ...
};

export const eventsReducer = createReducer(
    initialState,
    on(EventsApiActions.eventsLoaded, (state, action) => {
        return {
            ...state,
            collection: action.events
        };
    }),
    ...
);

现在,您可以通过以下方法将事件集合传递到collection: action.eventsfilterFn实用函数中,而不是使用filterFn来更改事件集合:

代码语言:javascript
复制
const mappedEvents = (events: CalendarEvents[]) =>
    events.map((event) => event.start = new Date(event.start))
});

现在你可以在这里使用它:

代码语言:javascript
复制
on(EventsApiActions.eventsLoaded, (state, action) => {
    return {
        ...state,
        collection: mappedEvents(action.events)
    };
}),

最后,选择器(events.reduce.ts):

代码语言:javascript
复制
export const selectAll = (state: State) => state.collection;
export const selectEventsState = (state: State) => state.events;
export const selectAllEvents = createSelector(
    selectEventsState,
    selectAll
);
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68776288

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档