0

我想实现每个主路由的代码拆分,以便每个页面都有自己的文件(及其子组件),例如我有一个主渲染函数,其中Route包含指向容器的组件:

    <Route path={`path1`} component={foo.container} />
    <Route path={`path2`} component={bar.container} />

每个容器看起来像这样:

const mapDispatchToProps = {
... actions etc ...
}

const mapStateToProps = (state) => ({
... selectors etc ...
})

const withConnect = connect(mapStateToProps, mapDispatchToProps);

export default compose(withConnect)(MyComponent);

我试图包装一个容器并在路由中引用它,但它不起作用:

export default Loadable({
  loader: () => import('./MyContainer'),
  loading() {
    return (<div>Loading...</div>)
  },
});

那么应该包装什么呢?

4

1 回答 1

1

这是一个简化的示例,如何使用react-routerand实现代码拆分react-loadable

MyPage.jsx -您要在单独文件中生成的页面

import React from 'react';

const MyPage = () => (
    <div>My page</div>
);

export default MyPage;

LoadableMyPage.jsx -使您的页面可加载的包装器

import React from 'react';
import Loadable from 'react-loadable';

const LoadableMyPage = Loadable({
    loader: () => import('./MyPage'),
    loading: () => <div>Loading...</div>,
});

const LoadableMyPage = () => (
    <LoadableMyPage />
);

export default LoadableMyPage;

路由器.jsx

import React from 'react';
import { Switch, Route } from 'react-router-dom';
import LoadableMyPage from './LoadableMyPage';

const Router = () => (
    <Switch>
        <Route path="/" exact component={LoadableMyPage} />
        ...
    </Switch>
);

正如@Mohit Tilwani 提到的,动态导入插件是必需的,因为它目前在stage-3ECMAScript 中,但还不是它的一部分。

https://github.com/tc39/proposal-dynamic-import

我开始研究我自己的 React 样板,在那里我实现了相同的代码拆分。如果您卡住了,请不要犹豫检查它。

https://github.com/peetya/react-boilerplate

于 2018-08-08T12:12:57.223 回答