- 背景:升级webpack5 + 使用preload插件
- 报错信息:
compiler.plugin is not a function
- 关键代码:手动引入preload插件
const PreloadWebpackPlugin = require('preload-webpack-plugin')
plugins: [
new PreloadWebpackPlugin({
rel: 'prefetch',
fileBlacklist:[/.*\.(js|map|css)$/]
})
],
- 问题:根据webpack5源码分析,webpack5与preload插件不相容导致报错;除了preload插件外,任何与webpack5不相容的插件都将导致报错
- 解决:可以使用preload插件的替代品,但配置信息无法完全替换,需要逐一排查
const PreloadWebpackPlugin = require('@vue/preload-webpack-plugin')
plugins: [
new PreloadWebpackPlugin({
rel: 'prefetch',
fileBlacklist:[/.*\.(js|map|css)$/]
})
],