如何使用 indexedDB 的承诺在 @ngrx/core 中设置 initialState

How to set initialState in @ngrx/core with a promise from indexedDB

我想使用 idb 包在 ngrx 中设置初始状态,该包使用 promise 来获取数据,但每次我尝试设置它时都会出错。我读到 @ngrx 是同步的,这是否意味着它不适用于承诺。 我尝试过的不同方法:

这是我的 idb 包装器方法,它加载数据时工作正常

export function getInitialState(): Promise<any> {
  return StorageService.dB.loadInitialState('app-state');
}

以及我尝试设置初始状态的不同方法

方法:1

StoreModule.forRoot(reducers, {initialState: getInitialState})

方法:2

 import { INITIAL_STATE } from '@ngrx/store';
{ provide: INITIAL_STATE, useFactory: getInitialState }

方法:3

export function logger(reducer: ActionReducer<State>): ActionReducer<State> {
  return function (state: State, action: any): State {
   if(action.type === '@ngrx/store/init') {

   }
    return reducer(state, action);
  };

}

初始状态设置为此

ZoneAwarePromise {__zone_symbol__state: null, __zone_symbol__value: Array(0)}

我收到这个错误

ERROR TypeError: Cannot assign to read only property '__zone_symbol__state' of object '[object Object]'
    at resolvePromise (zone.js:810)
    at eval (zone.js:876)
    at ZoneDelegate.invokeTask (zone.js:425)
    at Object.onInvokeTask (core.js:4747)
    at ZoneDelegate.invokeTask (zone.js:424)
    at Zone.runTask (zone.js:192)
    at drainMicroTaskQueue (zone.js:602)
    at ZoneTask.invokeTask [as invoke] (zone.js:503)
    at invokeTask (zone.js:1540)
    at IDBRequest.globalZoneAwareCallback (zone.js:1566)

*****更新*******

我现在明白了,因为 dee zg 指出每个状态都可以在它们的效果中有一个 init 函数,当它们被加载时,我认为这是一个全局的一次性事件。这是我用于 Auth state

 @Effect()
  init$: Observable<Action> = defer(() => {
    return from(StorageService.readItem('app', Auth.AUTH_KEY)).pipe(
       map((data: any) => {
        return new Auth.AuthInit(data.state);
      })
    );
  });

效果中有一个 init 动作,当效果达到 运行 时触发。在那里你可以发送你的动作,获取数据并填充初始状态。 在此处检查 Init Action 部分: https://github.com/ngrx/platform/blob/master/MIGRATION.md