如何在webpack配置中获取模式,例如,推送一些插件。
package.json
"scripts": {
"dev": "webpack --mode development",
"build": "webpack --mode production"
}
我在webpack 3中做了什么
package.json
"scripts": {
"build": "cross-env NODE_ENV=development webpack",
"prod": "cross-env NODE_ENV=production webpack"
},
然后,我能够通过process.env.NODE_ENV
当然,我可以通过NODE_ENV
传递--mode
,但我更愿意避免重复。
答案 0 :(得分:28)
您希望避免重复在脚本上传递的选项。
导出函数时,将使用2个参数调用该函数:环境作为第一个参数,选项图作为第二个参数。
的package.json
"scripts": {
"build-dev": "webpack --mode development",
"build-prod": "webpack --mode production"
},
webpack.config.js
module.exports = (env, options) => {
console.log(`This is the Webpack 4 'mode': ${options.mode}`);
return {
...
};
}
结果如下:
npm run build-dev
:
> webpack --mode development
This is the Webpack 4 'mode': development
Hash: 554dd20dff08600ad09b
Version: webpack 4.1.1
Time: 42ms
Built at: 2018-3-14 11:27:35
npm run build-prod
:
> webpack --mode production
This is the Webpack 4 'mode': production
Hash: 8cc6c4e6b736eaa4183e
Version: webpack 4.1.1
Time: 42ms
Built at: 2018-3-14 11:28:32
答案 1 :(得分:2)
试试这个
的package.json
"scripts": {
"dev": "webpack --mode development",
"build": "webpack --mode production --env.production"
}
所以,如果您使用env
内的webpack config
,看起来像这样
module.exports = env => {
const inProduction = env.production
return {
entry: {...},
output: {...},
module: {...}
}
}
有关设置webpack.config.js
的详细信息。 (Environment Variables for webpack 4)
答案 2 :(得分:2)
要测试是否处于生产模式,请在webpack.config.js
文件中使用以下命令:
const isProduction = process.argv[process.argv.indexOf('--mode') + 1] === 'production';
const config = {
...
};
if (isProduction) {
config.plugins.push(new MiniCssExtractPlugin());
} else { // isDev
config.devtool = /*'source-map'*/ 'inline-source-map';
}
module.exports = config;
停止尝试NODE_ENV
是老学校( webpack 3 )。
这更适合与import / webpack resolver
答案 3 :(得分:0)
我最终(ab)使用npm_lifecycle_script
在DefinePlugin
中设置了模式:
MODE: JSON.stringify(process.env.npm_lifecycle_script.substr(process.env.npm_lifecycle_script.indexOf('--mode ') + '--mode '.length, process.env.npm_lifecycle_script.substr(process.env.npm_lifecycle_script.indexOf('--mode ') + '--mode '.length).search(/($|\s)/)))
这将从发出的--mode
命令中获取webpack
参数的值。