我已经阅读了堆栈溢出中的所有文章以及来自谷歌搜索的大约 200 多篇文章,而且我一生都无法理解 process.env。无论我做什么,它始终是一个空对象。
const path = require("path");
const webpack = require('webpack');
module.exports = {
entry: {
search: './src/search/search_index.js',
// search: './src/search/search_index.js'
},
output: {
path: path.join(__dirname, "../website/public/javascript/react"),
publicPath: '/',
filename: "[name].bundle.js"
},
module: {
loaders: [{
exclude: /node_modules/,
loader: 'babel',
query: {
presets: ['react', 'es2015', 'stage-1']
}
}]
},
resolve: {
extensions: ['', '.js', '.jsx']
},
devServer: {
historyApiFallback: true,
contentBase: './'
},
plugins: [
new webpack.DefinePlugin({
"process.env" : {
'NODE_ENV': '"production"'
}
})
]
};
"scripts": {
"start": "webpack-dev-server --inline --hot --content-base src/search",
"test": "mocha --compilers js:babel-core/register --require ./test/test_helper.js --recursive ./test",
"test:watch": "npm run test -- --watch"
}
console.log(process.env);
//来自正在运行的应用程序中的渲染方法,以 "npm start"
开始总是返回
{}
我试图在我的构建中将 NODE_ENV 设置为生产,并且 %NODE_ENV% 显示生产的运气为零,但不管我在控制台中收到关于它在较慢的构建上运行以使用 NODE_ENV 生产的警告消息。
为了尝试解开正在发生的事情,我只是想看看我的应用程序在 process.env 中得到了什么,它是一个空对象。然后我尝试使用defineplugin对其进行硬编码,以再次测试正在发生的事情,结果是相同的。
我的头撞到了这个大约 3 个小时。任何帮助表示赞赏。
最佳答案
您正在使用的 DefinePlugin
配置将代码中出现的 process.env.NODE_ENV
表达式替换为您配置的任何值 - 它不会触及对 process.env
的引用,因为您没有告诉它对您进行任何配置using 只是替换共享公共(public)根的多个表达式的简写。
Webpack 检测到您正在引用全局 process
变量,并且正在从 process
mock 注入(inject) node-libs-browser ,如您所见,它定义了一个空的 0x2518321431134。
您可以使用 env
Webpack config 来控制它。将 node
添加到您的配置中将禁用 node: {process: false}
的模拟注入(inject)。
关于node.js - webpack react process.env 始终为空(Windows 10),我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/41248575/