我已经阅读了堆栈溢出中的所有文章以及来自谷歌搜索的大约 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/

10-17 02:54