我无法将 redux-devtools-extension 与 react-router-redux 的 syncHistoryWithStore 一起使用。我得到的错误是 Uncaught TypeError: store.getState is not a function。
syncHistoryWithStore@sync.js:38(匿名函数)@store.js:30
我的商店.js
import { createStore, applyMiddleware, compose } from 'redux';
import { syncHistoryWithStore } from 'react-router-redux';
import { browserHistory } from 'react-router';
import thunkMiddleware from 'redux-thunk';
import createLogger from 'redux-logger';
import rootReducer from './reducers/reducers';
import devTools from 'remote-redux-devtools';
const loggerMiddleware = createLogger()
import data from './dummydata/data'
// dummy data is an export of an array of objects
//
// {
// const data = [
// {
// "Id":"BAcyDyQwcXX",
// "labels": ['P1', 'P2', 'P3', 'P4', 'P5/P6'],
// "series": [[1, 2, 3, 4, 5]],
// "total": 0
// }
// ]
// }
const initialState = {
data
};
//const store = createStore(rootReducer, initialState)
//it works when i use this, but when try to implement the devTools extension,
//the error fires.
const store = function configureStore(initialState) {
const storeCreator = createStore(rootReducer, initialState,
window.devToolsExtension && window.devToolsExtension()
);
return storeCreator;
}
export const history = syncHistoryWithStore(browserHistory, store)
export default store;
我的 rootReducer.js
import { combineReducers } from 'redux'
import { routerReducer } from 'react-router-redux';
function post(state = [], action) {
console.log("state: ", state, "action: ", action);
return state
}
const rootReducer = combineReducers({
post, routing: routerReducer
})
export default rootReducer
我的 main.js
import React from 'react';
import { render } from 'react-dom';
import { Provider } from 'react-redux';
import css from './styles/stylesheets/style.css';
import store, { history } from './store';
import Main from './components/Main';
import Index from './components/Index';
import Single from './components/Single';
import GraphChart from './components/GraphChart';
import { Router, Route, IndexRoute } from 'react-router';
const router = (
<Provider store={store}>
<Router history={history}>
<Route path="/" component={Main}>
<IndexRoute component={GraphChart}></IndexRoute>
<Route path="/view" component={Single}></Route>
</Route>
</Router>
</Provider>
)
render(router, document.querySelector('#react-container'));