首页 > 解决方案 > .env 变量在 create-react-app UI 中显示为未定义

问题描述

我正在尝试设置特定于构建的环境变量,以便在使用create-react-app初始化的前端(不是NodeJS)ReactJS 应用程序中使用。

我在项目根目录中创建了三个文件:.env、.env.development、.env.production

出于测试目的,我将这些变量放在每个 .env 文件中:

REACT_APP_TEST_KEY=1
TEST_KEY=1

在渲染函数的 app.js 文件中,我添加了以下调试行:

  console.log(`.env test key: ${process.env.REACT_APP_TEST_KEY}`);
  console.log(`.env test key: ${process.env.TEST_KEY}`);

全部保存后,我在命令行运行npm start

结果如下:

.env test key: undefined
.env test key: undefined

如您所见,我试图对是否应该使用前置REACT_APP进行对冲。

我花了几个小时查看关于这个主题的各种博客文章,以及关于这个主题的两个最受欢迎的问题,但我仍然觉得我没有答案,特别是因为一些回复混淆了它是否ll 仅在 node 中而不在浏览器中工作,并且 create-react-app 文档有些相同尚未更新。

顺便说一句,该文档清楚地暗示这应该开箱即用,无需对 package.json 文件进行额外编辑。无论如何,我已将其包含在下面:

  "name": "ui",
  "version": "0.1.0",
  "private": true,
  "dependencies": {
    "@testing-library/jest-dom": "^4.2.4",
    "@testing-library/react": "^9.5.0",
    "@testing-library/user-event": "^7.2.1",
    "msal": "^1.3.0",
    "react": "^16.13.1",
    "react-dom": "^16.13.1",
    "react-router-dom": "^5.1.2",
    "react-scripts": "3.4.1",
    "react-stl-obj-viewer": "^1.2.0"
  },
  "scripts": {
    "start": "react-scripts start",
    "build": "react-scripts build",
    "test": "react-scripts test",
    "eject": "react-scripts eject"
  },
  "eslintConfig": {
    "extends": "react-app"
  },
  "browserslist": {
    "production": [
      ">0.2%",
      "not dead",
      "not op_mini all",
      "ie 11"
    ],
    "development": [
      "last 1 chrome version",
      "last 1 firefox version",
      "last 1 safari version",
      "ie 11"
    ]
  },
  "devDependencies": {
    "node-sass": "^4.13.1"
  }

标签: reactjscreate-react-appdotenv

解决方案


您似乎可能在文档之后遗漏了一些要点,我尝试在我的本地存储库和代码和框存储库上复制这些步骤以查看 env 变量。

他们俩似乎都在记录预期的环境变量。

有关更多详细信息,请参阅此代码和框repo。如果您将代码托管在其他地方,请分享 repo 详细信息。


推荐阅读