Консоль регистрирует данные о состоянии при использовании ngrx для State Management в Angular - PullRequest
0 голосов
/ 11 октября 2018

Может кто-нибудь подсказать, как консольно регистрировать состояние при использовании ngrx для управления состоянием в угловых приложениях.Я прошел через ngrx-store-logger, но в документации не ясно, как создавать метаредукторы и использовать эту библиотеку.

1 Ответ

0 голосов
/ 12 октября 2018

Это можно сделать с помощью метаредуктора, как показано в примере приложения NgRx

export function logger(reducer: ActionReducer<State>): ActionReducer<State> {
  return (state: State, action: any): any => {
    const result = reducer(state, action);
    console.groupCollapsed(action.type);
    console.log('prev state', state);
    console.log('action', action);
    console.log('next state', result);
    console.groupEnd();

    return result;
  };
}

/**
 * By default, @ngrx/store uses combineReducers with the reducer map to compose
 * the root meta-reducer. To add more meta-reducers, provide an array of meta-reducers
 * that will be composed to form the root meta-reducer.
 */
export const metaReducers: MetaReducer<State>[] = !environment.production
  ? [logger, storeFreeze]
  : [];
...