3

主要问题是在使用 react-routerV4 和 webpack 2 进行代码拆分时,我有几个模块,我无法到达主要模块。

我的配置如下:

  • 网页包 2.2.1
  • 反应路线 4.1.1

我正在使用 react-router v4文档中的代码拆分

基本上,我不使用导入,但在路由配置上我有:像这样:

import loadHome from 'bundle-loader?lazy&name=home-chunk!./pages/market/Home';
[
  {
    path: url1,
    component: props => <Bundle load={loadHome}>{Home => <Home {...props} />}</Bundle>,
    exact: true,
  },
  // other routes
  ]

这对代码拆分非常有效,我为每个路由获得一个包,为 node_modules 获得另一个包,我稍后可以拆分。

我的问题是,我有一个 node_module (react-slick),它位于多个捆绑包中。所以我想把它放在主包里。

我的 webpack 配置是:

module.exports = {
  entry: [
    'whatwg-fetch',
    './src/scripts/index.js',
  ],
  output: {
    path: path.resolve(__dirname, 'src/build'),
    publicPath: '/build/',
    chunkFilename: "[name].js?[hash]",
    filename: '[name].js',
  },
  plugins: [
    new BundleAnalyzerPlugin(),
    new webpack.DefinePlugin({
      'process.env': {
        'NODE_ENV': '"production"'
      }
    }),
    new webpack.optimize.CommonsChunkPlugin({
      name: ['4_node-modules'],
      minChunks(module) {
       const context = module.context;
       return context && context.indexOf('node_modules') >= 0;
      },
    }),
    new webpack.optimize.CommonsChunkPlugin({
      name: ['3_react'],
      chunks: ['4_node-modules'],
      minChunks(module) {
        return module.context && /.*\/react.*/.test(module.context);
      },
    }),
    new webpack.optimize.CommonsChunkPlugin({
        children: true,
        minChunks: 2,
    }),
    new ExtractTextPlugin({
      filename: '[name].css',
      allChunks: true,
    }),
    new HtmlWebpackPlugin({
      filename: '../index.prod.html',
      template: 'src/template.index.prod.html',
      inject: false,
      hash: true,
    }),
  ],
};

根据文档,这应该可以解决问题:

new webpack.optimize.CommonsChunkPlugin({
    children: true,
    minChunks: 2,
}),

但是什么也没发生,我的 3 个捆绑包中仍然有“react-slick”。

有没有人暗示发生了什么?

任何帮助表示赞赏:) 谢谢!

4

2 回答 2

3

我终于得到了解决方案;)

我让这个,所以它可能会帮助某人。

答案是:不指定块显然不是针对所有块,而是只针对最后一个创建的块。

因此,假设使用 react-router V4,我们创建了 2 个异步块“home-chunk”和“welcome-chunk”。从中获取公共块的方法是在 webpack 配置文件中添加(在插件中):

new webpack.optimize.CommonsChunkPlugin( {
  name : 'common',
  chunks : ['home-chunk', 'welcome-chunk'],
  minChunks : 2,
}),

这将检查异步块中是否有公共模块,如果有,将它们放入公共块中。

于 2017-07-05T12:14:04.807 回答
-1

从此处复制以下答案:如何跨块删除重复的 Ant Design 组件


不修改webpack的解决方案:

在父组件(或更高的父组件)上,在此处执行完全相同的导入。

import { Row, Col, Button } from "antd"

您也可以React.lazy在这里导入。我认为没有必要,但您可以将它放在 auseEffect中,这样只有在安装父组件时,您的应用程序才会读取此代码。

useEffect(() => {
  React.lazy(() => import("antd"))
}, []);

在子组件中,使用与正常相同的代码导入以使用变量。Webpack 识别出这个模块已经被下载,因为父组件仍然存在,所以它不会将它们包含在新的包中。

import { Row, Col, Button } from "antd" 
于 2020-04-07T19:08:29.233 回答