0

参考までに、私は React-Redux スターター キット ( https://github.com/davezuko/react-redux-starter-kit ) をベース プロジェクト レイアウトとして使用しています。

という名前のルートがあり、コンテナ コンポーネントにレデューサーを注入するためにand reduxをTSP使用しています。getComponentconnect()children

getChildRoutesTSP ルート定義の が呼び出されることはありません。

ルート ルーター構成:

import ApplicationLayout from '../layouts/ApplicationLayout';
import Home from './Home';

export const createRoutes = (store) => {
  const routes = {
    path: '/',
    component: ApplicationLayout,
    indexRoute: Home,
    getChildRoutes (location, next) {
      require.ensure([], (require) => {
        next(null, [
          require('./TSP').default(store),
          require('./Home').default,
        ]);
      });
    }
  };

  return routes;
};

export default createRoutes;

ネストされたルーター構成 (TSP):

import { injectReducer } from '../../store/reducers';
import Overview from './routes/Overview';

export default (store) => ({
  path: '/tsp/:id',
  indexRoute: Overview,
  getComponent (nextState, next) {
    require.ensure([
      './containers/TSPContainer',
      './modules/tsp'
    ], (require) => {
      const TSP = require('./containers/TSPContainer').default;
      const reducer = require('./modules/tsp').default;

      injectReducer(store, { key: 'tsp', reducer });
      next(null, TSP);
    });
  },
  getChildRoutes (location, next) {
    debugger
    require.ensure([], (require) => {
      next(null, [
        // Provide store for async reducers and middleware
        require('./routes/Offers').default(store),
        require('./routes/Reviews').default(store)
      ]);
    });
  }
});

私はdebugger内にたどり着くことはありませんgetChildRoutes

ヘルプをいただければ幸いです。表示に必要なファイルが他にある場合は、それらを追加できます。

4

2 に答える 2

0

./TSPおよび./Homeルート定義を同期的にロードしましたか? require.ensureそうでない場合、それらのモジュールを依存関係として指定しないと機能しないと思います。

そう:

getChildRoutes (location, next) {
  require.ensure([
    './TSP',
    './Home'
  ], (require) => {
    next(null, [
      require('./TSP').default(store),
      require('./Home').default,
    ]);
  });
}
于 2016-05-11T05:06:48.280 に答える
0

理解した。IndexRoute上記のネストされたルーター構成の私TSPのものは、オブジェクトではなく関数でした (これは、react-router が発火する前に indexRoute がオブジェクトであると想定していたと想定していますgetChildRoutes)。

解決策は、解決済みの routeConfig を に割り当てることでしOverviewindexRoute

TSP/index.js

import { injectReducer } from '../../store/reducers';

export default (store) => ({
  path: '/tsp/:id',
  indexRoute: require('./routes/Overview').default(store),
  getComponent (nextState, next) {
    require.ensure([
      './containers/TSPContainer',
      './modules/tsp'
    ], (require) => {
      const TSP = require('./containers/TSPContainer').default;
      const reducer = require('./modules/tsp').default;

      injectReducer(store, { key: 'tsp', reducer });
      next(null, TSP);
    });
  },
  getChildRoutes (location, next) {
    require.ensure([], (require) => {
      next(null, [
        // Provide store for async reducers and middleware
        require('./routes/Offers').default(store),
        require('./routes/Reviews').default(store)
      ]);
    });
  }
});

TSP/routes/Overview/index.js

export default (store) => ({
  getComponent (nextState, next) {
    require.ensure([
      './components/OverviewView'
    ], (require) => {
      const Overview = require('./components/OverviewView').default;
      next(null, Overview);
    });
  }
});
于 2016-05-11T16:59:22.310 に答える