我正在尝试为我的项目设置环境变量NODE_ENV。
我正在使用Windows,并且已在系统设置中设置了NODE_ENV-已通过键入 SET 并在输出中的以下行进行标识来验证这一点。
NODE_ENV =生产
我似乎无法在Webpack中设置该变量。
将以下代码添加到我的项目(index.js)中时,它只会注销 未定义
console.log('PROCESS', process.env.NODE_ENV)
我的webpack配置:
const path = require('path');
const webpack = require('webpack');
const ExtractTextPlugin = require('extract-text-webpack-plugin');
const UglifyJSPlugin = require('uglifyjs-webpack-plugin')
process.env.NODE_ENV = process.env.NODE_ENV || 'development'
if (process.env.NODE_ENV === 'test') {
require('dotenv').config({ path: '.env.test' })
} else if (process.env.NODE_ENV === 'development') {
require('dotenv').config({ path: '.env.development' })
} else if (process.env.NODE_ENV === 'production') {
require('dotenv').config({ path: '.env.production' })
} else {
require('dotenv').config({ path: '.env.development' })
}
module.exports = (env) => {
const isProduction = env === 'production';
...
plugins: [
CSSExtract,
new UglifyJSPlugin(),
new webpack.DefinePlugin({
'process.env.FIREBASE_API_KEY': JSON.stringify(process.env.FIREBASE_API_KEY),
'process.env.FIREBASE_AUTH_DOMAIN': JSON.stringify(process.env.FIREBASE_AUTH_DOMAIN),
'process.env.FIREBASE_DATABASE_URL': JSON.stringify(process.env.FIREBASE_DATABASE_URL),
...
}),
devtool: isProduction ? 'source-map' : 'inline-source-map',
...
我有read this question,但仍然无法设置env变量。
我要去哪里错了?
答案 0 :(得分:0)
我设法通过使用cross-env包来设置NODE_ENV! 如果要在Windows上开发node.js,这可能会非常有用。 Linux / Mac用户不会有此问题。
要设置环境变量,只需键入
跨环境NODE_ENV =生产[您的赞扬在这里]
示例:
cross-env NODE_ENV =生产webpack --env生产