0

作为参考,我使用 React-Redux Starter Kit ( https://github.com/davezuko/react-redux-starter-kit ) 作为基础项目布局。

我有一个名为 的路由TSP,我正在使用getComponent和 reduxconnect()在容器组件上注入一个 reducer,我希望它会children在 props 中传递。

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

弄清楚了。我IndexRoute在上面的TSP嵌套路由器配置中是一个函数,而不是一个对象(我假设 react-router 在触发之前期望 indexRoute 是一个对象getChildRoutes。)

解决方案是将已解析的 routeConfig 分配给Overviewto indexRoute

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 回答
0

Have you synchronously loaded the ./TSP and ./Home route definitions? If not, I don't think require.ensure would work without you specifying those modules as dependencies.

So:

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