web-dev-qa-db-ja.com

connectedRouterエラー:状態ツリーでルーターレデューサーが見つかりませんでした。「ルーター」の下にマウントする必要があります

私はReact.jsを使い始めたばかりで、ベースプロジェクトをセットアップしていたときに、ルーティングが変更されたがコンポーネントがロードされないという問題が発生しました。グーグル検索した後、ConnectedRouterを使用する必要があることがわかりました。 ConnectedRouterのセットアップ中にコンソールエラーが発生します。 状態ツリーでルーター減速機が見つかりませんでした。「ルーター」の下にマウントする必要があります

import React from 'react';
import ReactDOM from 'react-dom';
import { BrowserRouter } from 'react-router-dom';
import { ConnectedRouter, connectRouter, routerMiddleware } from "connected-react-router";
import { Provider } from "react-redux";
import { createStore, combineReducers, applyMiddleware, compose } from 'redux';
import createSagaMiddleware from 'redux-saga';
import loginReducer from "./store/reducers/login";
import { watchLogin} from "./store/sagas";
import { history } from '../src/shared/history';
import { Push } from 'react-router-redux';



import './index.css';
import App from './App';

const composeEnhancers = window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__ || compose;

const rootReducer = combineReducers({
    login: loginReducer
});
const routersMiddleware = routerMiddleware(history)
const sagaMiddleware = createSagaMiddleware();
const middlewares = [sagaMiddleware, routersMiddleware];

const store = createStore(
    connectRouter(history)(rootReducer),
    {},
    composeEnhancers(applyMiddleware(...middlewares))
);

sagaMiddleware.run(watchLogin);

const app = (
    <Provider  store={store}>
        <ConnectedRouter  history={history}>
            <App />
        </ConnectedRouter>
    </Provider>
);

ReactDOM.render(app, document.getElementById('root'));

11
user4556641

immutableを使用する場合は、「connected-react-router/immutable」からConnectedRouterをインポートする必要があります。

0
Alexander Elgin