Почему я получаю TypeError: Object (...) не является ошибкой функции при использовании redux? - PullRequest
0 голосов
/ 26 апреля 2019

Я пытаюсь использовать избыточность с реакцией, но я сталкиваюсь с ошибкой TypeError: Object (...) не является ошибкой функции. Я не могу понять, почему я продолжаю получать эту ошибку, и это происходит только на странице, которая использует этот компонент Survey, поэтому я знаю, что это определенно избыточно, что где-то портит. Некоторая помощь будет очень признательна.

import React from 'react';
import ReactDOM from 'react-dom';
import { createStore } from 'redux';
import { Provider } from 'react-redux';
import surveyReducer from './reducers/survey-reducer.js'
import App from './App';
import * as serviceWorker from './serviceWorker';
import { BrowserRouter } from 'react-router-dom';

const store = createStore(
  surveyReducer,
  window.__REDUX_DEVTOOLS_EXTENSION__ && window.__REDUX_DEVTOOLS_EXTENSION__()
);

ReactDOM.render((
  <BrowserRouter>
    <Provider store={store}>
        <App />
    </Provider>
  </BrowserRouter>
),document.getElementById('root'));

serviceWorker.unregister();

import React from 'react';
import NavBar from './NavBar';
import { connect } from 'react-redux';
import '../scss/Survey.scss';

class Survey extends React.Component {

  constructor(props) {
    super(props);
    let root = document.querySelector('#root');
    root.className = '';
    root.classList.toggle('survey-root');
  }

  render() {
    return(
      <>
        <NavBar />
        <div>

        </div>
      </>
      )
  }
}

const mapStateToProps = state => {
  return {
    questions: state
  };
}

const mapDispatchToProps = dispatch => {
  return {
    chooseAnswer: (action) => dispatch(action)
  };
}

export default connect(mapStateToProps, mapDispatchToProps)(Survey);

export default function surveyReducer (state = {
    Q1: '',
    Q2: '',
    Q3: '',
    Q4: '',
    Q5: '',
    Q6: '',
    Q7: '',
    Q8: '',
    Q9: '',
    Q10: '',
    Q11: '',
    Q12: '',
    Q13: '',
    Q14: '',
    Q15: '',
    Q16: '',
    Q17: ''
  }, action) {
  switch (action.question) {
    case 'Q1':
      return {...state, Q1: action.answer};
    case 'Q2':
      return {...state, Q2: action.answer};
    case 'Q3':
      return {...state, Q3: action.answer};
    case 'Q4':
      return {...state, Q4: action.answer};
    case 'Q5':
      return {...state, Q5: action.answer};
    case 'Q6':
      return {...state, Q6: action.answer};
    case 'Q7':
      return {...state, Q7: action.answer};
    case 'Q8':
      return {...state, Q8: action.answer};
    case 'Q9':
      return {...state, Q9: action.answer};
    case 'Q10':
      return {...state, Q10: action.answer};
    case 'Q11':
      return {...state, Q11: action.answer};
    case 'Q12':
      return {...state, Q12: action.answer};
    case 'Q13':
      return {...state, Q13: action.answer};
    case 'Q14':
      return {...state, Q14: action.answer};
    case 'Q15':
      return {...state, Q15: action.answer};
    case 'Q16':
      return {...state, Q16: action.answer};
    case 'Q17':
      return {...state, Q17: action.answer};
    default:
      return state;
  }
}

1 Ответ

0 голосов
/ 26 апреля 2019

Это были версии зависимостей, моя версия пакета реакции не была совместима с установленным мной редуксом. Что за головная боль.

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