0

我仍在尝试学习 ngrx - 商店已设置好,一切似乎都运行良好。我使用的数据库是 SQL,所以基本上我是“克隆”表并将它们加载到存储中,但在选择员工时最终加入状态时遇到问题。

员工实体看起来像这样:

export class Employee = {
  id: number;
  firstName: string;
  lastName: string;
  degreeId?: number;
  degree: Degree;
}

export class Degree = {
  id: number;
  description: string;
}

现在在我的组件中,我想让特定员工显示如下:

{
  id: 1,
  firstName: George,
  lastName: Costanza,
  degreeId: 2,
  degree: {
    id: 2,
    description: 'College'
  }
}

我尝试的是创建一个合并这两个实体的选择器:

export const getEmployeeWithAllData = createSelector(
  getSelectedEmployee,
  getRelationalData,
  (employee, data) => {
    const employeesDegree = degree[employee.degreeId]
    employee.degree = employeesDegree

    return employee;
  }
);

如果我不使用 ngrx-store-freeze,这似乎确实有效 - 所以因为我不知道我是否正确创建了选择器或者 ngrx-store-freeze 是否有错误,所以我在问这个问题。

当我这样做时,我真的在改变状态吗?

如果是,我如何从我的商店中选择具有他拥有的所有关系数据的特定员工?

我正在做的事情感觉不太对劲。在我的实际应用程序中,员工有大约 8 个我需要加入的关系数据字段......

编辑:我忘了包括错误 ngrx-store-freeze 抛出:

ERROR TypeError: Cannot assign to read only property 'degree' of object '[object Object]'
at eval (employee.selector.ts:85)
at eval (store.es5.js:602)
at memoized (store.es5.js:539)
at defaultStateFn (store.es5.js:573)
at eval (store.es5.js:605)
at MapSubscriber.memoized [as project] (store.es5.js:539)
at MapSubscriber._next (map.js:79)
at MapSubscriber.Subscriber.next (Subscriber.js:95)
at MapSubscriber._next (map.js:85)
at MapSubscriber.Subscriber.next (Subscriber.js:95)
4

1 回答 1

0

是的,您正在尝试改变状态。您可以像下面这样简单地防止这种情况

export const getEmployeeWithAllData = createSelector(
  getSelectedEmployee,
  getRelationalData,
  (employee, data) => {
    const emp = JSON.parse(JSON.stringify(employee)
    emp.degree = degree[employee.degreeId]

    return emp;
  }
)
于 2018-04-21T16:03:12.813 回答