我尝试使用webpack 4进行代码拆分(以前的配置,webpack 3正常工作)
我创建了一个存储库,可以轻松地重现我的问题:https://github.com/iamdey/RD-webpack4-code-split
我一直陷入以下错误,因为我想在供应商包中进行代码拆分和babel-polyfill:
ReferenceError:未定义regeneratorRuntime
这是我的webpack配置:
{
entry: {
app: ['./src/index.js'],
vendor: [
'babel-polyfill',
'moment',
],
},
output: {
filename: '[name].[chunkhash].js',
chunkFilename: '[name].[chunkhash].js',
},
plugins: [
new HtmlWebpackPlugin({
chunksSortMode: (chunk1, chunk2) => {
// make sure babel-polyfill in vendors is loaded before app
const order = ['manifest', 'vendor', 'app'];
const order1 = order.indexOf(chunk1.names[0]);
const order2 = order.indexOf(chunk2.names[0]);
return order1 - order2;
},
}),
],
optimization: {
runtimeChunk: {
name: 'manifest',
},
splitChunks: {
cacheGroups: {
vendor: {
chunks: 'initial',
name: 'vendor',
test: 'vendor',
enforce: true,
},
},
},
}
}
调试时,我们看到供应商在清单和最终应用之后立即加载。 但是应用在供应商之前执行。
如果我删除splitChunks
选项,就像清单之前一样,然后加载供应商,但在加载应用程序之前直接执行供应商。
在这种情况下,问题是拆分产生了不良影响:在供应商和应用程序中重复了块。
以下是我的选择:
答案 0 :(得分:1)
让我们首先将polyfill加载并作为每个入口点的一部分执行(如babel-polyfill doc中所示),以便它看起来像这样
app: ['babel-polyfill', './src/index.js'],
vendor: ['moment'],
这是npm run start2
之后的输出:
Asset Size Chunks Chunk Names
app.53452b510a24e3c11f03.js 419 KiB app [emitted] app
manifest.16093f9bf9de1cb39c92.js 5.31 KiB manifest [emitted] manifest
vendor.e3f405ffdcf40fa83b3a.js 558 KiB vendor [emitted] vendor
我的理解是在babel-polyfill
中设置entry.app
告诉webpack应用程序需要填充。供应商中定义的包告诉splitChunk插件要在缓存组中捆绑哪些包。
根据我对split-chunks-plugin doc
的理解测试选项控制此缓存组选择的模块。省略它会选择所有模块。
因此,从test
选项中删除cacheGroup
将导致所有代码都将移至供应商包。
知道我们有2个解决方案。
{
entry: {
app: [
'babel-polyfill',
'./src/index.js',
],
vendor: [
'babel-polyfill',
'moment',
],
},
optimization: {
splitChunks: {
cacheGroups: {
vendors: {
chunks: 'initial',
name: 'vendor',
test: 'vendor',
enforce: true,
},
},
},
runtimeChunk: {
name: 'manifest',
},
},
}
因此,我们告诉webpack应用程序需要babel-polyfill
,我们告诉splitChunks
babel-polyfill
和moment
供应商要在缓存组中使用。
在index.js
中import 'babel-polyfill';
import moment from 'moment';
// ...
webpack.config.js
{
entry: {
app: [
'./src/index.js',
],
vendor: [
'babel-polyfill',
'moment',
],
},
// ...
这样可以确保应用程序需要填充。
希望它有所帮助!