store.getstate () оценивается как неопределенное - PullRequest
1 голос
/ 30 июня 2019

в реактивном проекте, я продолжаю нажимать на эту ошибку: состояние не определено, оценивая store.getstate ()

// store.js

 const composeEnhancers =
          typeof window === "object" &&                     window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__
    ? window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__({})
    : compose;

const enhancer = composeEnhancers(applyMiddleware(thunk));



const Store = createStore(
  combineReducers(
    {
      form: formReducer,
      appointmentsReducer
    },
    enhancer
  )
);
console.log(Store.getState());

export default Store;`

// reducer.js

import {
    FETCH_APPOINTMENTS_BEGIN,
    FETCH_APPOINTMENTS_SUCCESS,
    FETCH_APPOINTMENTS_FAILURE
  } from '../actions/appointmentsAction';

  const initialState = {
    data: [],
    loading: false,
    error: null
  };

  export default function appointmentsReducer(state = initialState, action) {
    switch(action.type) {
      case FETCH_APPOINTMENTS_BEGIN:

        return {
          ...state,
          loading: true,
          error: null
        };

      case FETCH_APPOINTMENTS_SUCCESS:

        return {
          ...state,
          loading: false,
          data: action.payload.appointments
        };

      case FETCH_APPOINTMENTS_FAILURE:

        return {
          ...state,
          loading: false,
          error: action.payload.error,
          data: []
        };

      default:

        return state;
    }
  }

// actions.js

import { listUrl } from "../cst";

export const FETCH_APPOINTMENTS_BEGIN = "FETCH_APPOINTMENTS_BEGIN";
export const FETCH_APPOINTMENTS_SUCCESS = "FETCH_APPOINTMENTS_SUCCESS";
export const FETCH_APPOINTMENTS_FAILURE = "FETCH_PRODUCTS_FAILURE";

export const fetchAppointmentsBegin = () => ({
  type: FETCH_APPOINTMENTS_BEGIN
});

export const fetchAppointmentsSuccess = appointments => ({
  type: FETCH_APPOINTMENTS_SUCCESS,
  payload: { appointments }
});

export const fetchAppointmentsFailure = error => ({
  type: FETCH_APPOINTMENTS_FAILURE,
  payload: { error }
});

export function fetchAppointments() {
  return dispatch => {
    dispatch(fetchAppointmentsBegin());
    return fetch(listUrl)
      .then(handleErrors)
      .then(res => res.json())
      .then(json => {
        dispatch(fetchApointmentsSuccess(json.appointment));
        return json.appointment;
      })
      .catch(error => dispatch(fetchAppointmentsFailure(error)));
  };
}

// Handle HTTP errors since fetch won't.
function handleErrors(response) {
  if (!response.ok) {
    throw Error(response.statusText);
  }
  return response;
}

// app.js

функция экспорта по умолчанию App () {

  return (
    <Provider store={Store}>
      <Navigation  />
    </Provider>
  );
}

// компонент списка рендеринга:

const mapStateToProps = state => ({
  data: state.appointments.data,
  loading: state.loading,
  error: state.error
});

console.log store.getstate () дает:

Object {
  "appointmentsReducer": Object {
    "data": Array [],
    "error": null,
    "loading": false,
  },
  "form": Object {},

Я не уверен, где проблема. Это из-за неправильной обработки асинхронного вызова? Если я использую сагу для обработки извлечения, это решит проблему? Любая помощь будет оценена.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...