jan*_*ngo 9 javascript environment-variables node.js typescript dotenv
我尝试了一些实现,但没有成功。
eval在 package.json 脚本中使用"fetch:data": "eval $(cat .env) ts-node -O '{\"module\":\"commonjs\"}' ./bin/build-api-data.ts"。
这会导致 JSON 解析错误,因为 eval 由于某种原因删除了我的引号。
undefined:1
{module:commonjs}
^
SyntaxError: Unexpected token m in JSON at position 1
Run Code Online (Sandbox Code Playgroud)
使用 dotenv,我在这里遇到的问题是竞争条件导致如下错误:
$ CANDID_ENV=local ts-node -O '{"module":"commonjs"}' ./bin/build-api-data.ts
/Users/lassiter.gregg/code/candidco-web/node_modules/contentful/dist/webpack:/contentful/contentful.js:49
throw new TypeError('Expected parameter accessToken')
^
TypeError: Expected parameter accessToken
Run Code Online (Sandbox Code Playgroud)
代码示例
undefined:1
{module:commonjs}
^
SyntaxError: Unexpected token m in JSON at position 1
Run Code Online (Sandbox Code Playgroud)
在上面的例子中,我尝试dotenv.config在文件顶部、init 和函数中进行操作,如您所见。它总是抛出相同的错误,即 contentful 未获取所需的环境变量。也就是说,如果我记录process.env并注释掉相关的代码,fetchApiData那么我会看到所有的环境变量。这就是为什么我认为这是比赛时的情况,但无法找到与我自己的问题类似的任何东西。
此外,更棘手的是,这是一个必须在 Node 和 esnext 环境中工作的自定义脚本。因此,我使用我不太喜欢的语法遇到了棘手的导入/导出问题,但还没有找到解决方法(例如export = someFunction)。
我是否正确地看到,您正在尝试使用使用 env 变量初始化的变量来配置 dotenv ?我认为这不会成功。Dotenv 的工作是将 env 变量加载到 process.env。您必须尽早在应用程序中配置它。
更多相关信息:https: //www.npmjs.com/package/dotenv
| 归档时间: |
|
| 查看次数: |
26831 次 |
| 最近记录: |