使用webpack 5设置一个简单的Middleman应用,但出现此无效的配置对象错误:
[webpack-cli]
Invalid configuration object. Webpack has been initialized using a configuration object that does not match the API schema.
- configuration.devtool should match pattern "^(inline-|hidden-|eval-)?(nosources-)?(cheap-(module-)?)?source-map$".
BREAKING CHANGE since webpack 5: The devtool option is more strict.
Please strictly follow the order of the keywords in the pattern.
devtool options listed here似乎没有一个错误,除了上面的错误以外,没有遗漏devtool或显式使其为错误。
这是我使用过webpack 4的设置,但是希望能对阻止无效配置错误有任何见解。
我的package.json
{
"name": "webpack5_practice",
"version": "1.0.0",
"description": "",
"main": "index.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"keywords": [],
"author": "",
"license": "ISC",
"devDependencies": {
"css-loader": "^4.3.0",
"mini-css-extract-plugin": "^1.0.0",
"node-sass": "^4.14.1",
"sass-loader": "^10.0.3",
"webpack": "^5.0.0",
"webpack-cli": "^4.0.0"
}
}
我的webpack.config.js
const path = require('path');
const MiniCssExtractPlugin = require('mini-css-extract-plugin');
module.exports = {
devtool: 'inline-source-map',
mode: 'development',
entry: {
site: ['./source/javascripts/site.js'],
style: ['./source/stylesheets/site.css.scss'],
},
output: {
path: path.resolve(__dirname, '.tmp/dist'),
filename: '[name].min.js',
},
module: {
rules: [
{
test: /\.(sa|sc|c)ss$/,
use: [
MiniCssExtractPlugin.loader,
'css-loader',
'sass-loader',
],
}
]
},
plugins: [new MiniCssExtractPlugin()],
};
我的config.rb带有webpack
# Webpack
activate :external_pipeline,
name: :webpack,
command: build? ? './node_modules/webpack/bin/webpack.js --bail' : './node_modules/webpack/bin/webpack.js --watch -d',
source: "./dist",
latency: 1
答案 0 :(得分:2)
回答我自己的问题并编辑原始问题以包括我的错误:
我正在config.rb中通过-d
标志通过Middleman外部管道运行Webpack。删除标志(或显式列出devtool选项)将解决此错误。