我尝试使用 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
选项,就像在清单之前一样,供应商会被加载,但供应商会在加载应用程序之前直接执行。在这种情况下,问题是拆分产生了不好的影响:块在供应商和应用程序中重复。
该怎么办 ?
以下是我的选择:
- 将 polyfill 放入应用程序包而不是供应商包中:我不想要那个
- 让 webpack 自己进行代码拆分:我不希望这样,因为在现实世界中,即使在供应商的版本之间,我也想要一个很长的缓存,并让应用程序尽可能小
- webpack 配置不正确:请告诉我 :)
- 这可能是一个错误:酷,我会尽快打开一个问题