从Webpack 4迁移到Webpack 5后,我遇到了一些问题。有时在构建并运行应用程序后,我会在devtools控制台中遇到如下错误:
Uncaught SyntaxError: Invalid or unexpected token
其中一个区块发生错误,导致应用程序无法启动。建置应用程序后,node_modules
程式码中的部分数字会被含字母的数字取代,程式码变成无效的JS。
以下是此类替换的示例:
.382683433 => .3a7f23433
590064 => 594c68
该问题已出现多次。以下操作有助于暂时解决该问题:
- 已删除
vendor
块 - 将
optimization.moduleIds
值从deterministic
替换为natural
- 将
realContentHash
值设置为false
但在几次MR后,问题再次出现,并停止了展开过程。
禁用最小化文件没有帮助。Babel不处理这些文件。
该项目使用:
- 节点版本12.22.7
- 网络套件v5.68.0
- 巴别塔v7.16.0
- 版本2.6.14
我的Webpack配置:
{
mode: 'production',
context: path.resolve(__dirname, '../'),
stats: 'errors-only',
entry: './src/main.js',
devtool: 'source-map',
output: {
path: path.resolve(__dirname, '../dist'),
publicPath: '/',
filename: utils.assetsPath('js/[name].[chunkhash:4].js'),
chunkFilename: utils.assetsPath('js/[name].[chunkhash:4].js')
},
resolve: {
extensions: ['.js', '.vue', '.json', '.ts'],
alias: {
'vue$': 'vue/dist/vue.esm.js',
'@': utils.resolve('src'),
'@test': utils.resolve('test'),
},
fallback: {
setImmediate: false,
fs: false,
dgram: false,
net: false,
tls: false,
child_process: false,
assert: require.resolve('assert'),
buffer: require.resolve('buffer'),
constants: require.resolve('constants-browserify'),
os: require.resolve('os-browserify/browser'),
path: require.resolve('path-browserify'),
stream: require.resolve('stream-browserify'),
util: require.resolve('util'),
vm: require.resolve('vm-browserify')
}
},
module: {
rules: [
{
test: /\.ts$/,
loader: 'ts-loader',
options: {
appendTsSuffixTo: [/\.vue$/],
},
include: [utils.resolve('node_modules/@ui-kit')]
},
{
test: /\.vue$/,
use: [
{
loader: 'vue-loader',
options: {
transformAssetUrls: {
video: ['src', 'poster'],
source: 'src',
img: 'src',
image: 'xlink:href'
}
}
}
],
},
{
test: /\.js$/,
loader: 'babel-loader',
include: [
utils.resolve('src'),
utils.resolve('test'),
utils.resolve('node_modules/vuetify'),
utils.resolve('node_modules/buffer')
]
},
{
test: /\.(png|jpe?g|gif|svg)(\?.*)?$/,
type: 'asset',
generator: {
filename: utils.assetsPath('img/[name].[contenthash:7].[ext]')
},
parser: {
dataUrlCondition: {
maxSize: 10 * 1024,
}
}
},
{
test: /\.(woff2?|eot|ttf|otf)(\?.*)?$/,
type: 'asset',
generator: {
filename: utils.assetsPath('fonts/[name].[contenthash:7].[ext]')
},
parser: {
dataUrlCondition: {
maxSize: 10 * 1024,
}
}
},
{
test: /\.css$/,
include: [
utils.resolve('node_modules/tinymce/skins/content/default/content.min.css'),
utils.resolve('node_modules/tinymce/skins/ui/oxide/content.min.css')
],
type: 'asset/source'
},
...utils.styleLoaders({
sourceMap: true,
extract: true
})
]
},
optimization: {
moduleIds: 'deterministic',
runtimeChunk: 'single',
splitChunks: {
cacheGroups: {
element: {
test: /[\\/]node_modules[\\/](element-ui)[\\/]/,
name: 'element',
chunks: 'all',
priority: 30
},
vendor: {
test: /[\\/]node_modules[\\/]/,
name: 'vendor',
chunks: 'initial',
priority: 20
},
common: {
name: 'common',
chunks: 'async',
minChunks: 2,
priority: 10,
reuseExistingChunk: true,
enforce: true
}
}
},
minimize: true,
minimizer: [
new TerserPlugin()
],
},
plugins: [
new VueLoaderPlugin(),
new VuetifyLoaderPlugin(),
new CopyWebpackPlugin({
patterns: [
{
from: path.resolve(__dirname, '../static'),
to: config.dev.assetsSubDirectory,
globOptions: {
ignore: ['.*'],
}
}
]
}),
new webpack.DefinePlugin({
'process.env': env
}),
new MiniCssExtractPlugin({
filename: utils.assetsPath('css/[name].[contenthash:4].css'),
chunkFilename: utils.assetsPath('css/[name].[chunkhash:4].css'),
ignoreOrder: true
}),
new HtmlWebpackPlugin({
filename: path.resolve(__dirname, '../dist/index.html'),
template: 'index.html',
inject: true,
minify: {
removeComments: true,
collapseWhitespace: true,
removeAttributeQuotes: true
}
}),
new RetryChunkLoadPlugin({
cacheBust: `function() {
return Date.now();
}`,
retryDelay: 1000,
maxRetries: 3
}),
new webpack.ContextReplacementPlugin(/moment[\/\\]locale$/, /ru/)
]
}
1条答案
按热度按时间xfb7svmp1#
请在此处尝试
[contenthash:8]