cross-env这是一款运行跨平台设置和使用环境变量的脚本。
为什么需要cross-env?
NODE_ENV=production
像这样设置环境变量时,大多数Windows命令提示符都会阻塞 。(Windows
上的Bash
是例外,它使用本机Bash。)同样,Windows和POSIX命令使用环境变量的方式也有所不同。对于POSIX,您可以使用:$ENV_VAR
和在Windows上可以使用%ENV_VAR%
。cross-env
这样,您就可以使用单个命令,而不必担心为平台正确设置或使用环境变量。就像在POSIX系统上运行时一样,只需对其进行设置即可,并且cross-env
会妥善设置。
在window下配置
1 | #node中常用的到的环境变量是NODE_ENV,首先查看是否存在 |
在linux下配置
1 | #node中常用的到的环境变量是NODE_ENV,首先查看是否存在 |
安装
一键安装不多解释
1 | npm install --save-dev cross-env |
警告!确保在安装软件包时可以正确拼写,以免错误安装恶意软件
注意:cross-env的版本6仅支持Node.js 8和更高版本,才能在Node.js 7或更低版本的安装版本5上使用
npm install --save-dev cross-env@5
使用
我在npm脚本中使用了它:
1 | { |
最终,执行的命令(使用cross-spawn)为:
1 | webpack --config build/webpack.config.js |
该NODE_ENV
环境变量将被设置cross-env
您也可以将命令拆分为多个命令,或者将环境变量声明与实际命令执行分开。您可以这样操作:
1 | { |
其中childScript
包含要执行的实际命令并parentScript
设置要使用的环境变量。然后,而不是运行childScript
,而是运行父项。这对于使用不同的env变量启动同一命令或当环境变量太长而无法将所有内容放在一行中时非常有用。这也意味着$GREET
即使在通常要求使用Windows的Windows上,也可以使用env var
语法%GREET%
。
如果您在美元符号前加上奇数个反斜杠,则不会替换表达式语句。请注意,这意味着在转义JSON字符串后使用了反斜杠。"FOO=\\$BAR"
将不会被替换。 "FOO=\\\\$BAR"
虽然会被替换。
最后,如果要传递JSON字符串(例如,使用ts-loader
时),则可以执行以下操作:
1 | { |
要特别注意三倍反斜线(\\\)
之前的 双引号(")
和缺少的单引号(')
。为了同时在Windows和UNIX上运行,必须同时满足这两个条件。
cross-env
与 cross-env-shell
该cross-env
模块公开了两个容器:cross-env
和cross-env-shell
。第一个使用来执行命令cross-spawn,第二个使用shellNode
的选项spawn
。
主要用例cross-env-shell
是当您需要在整个嵌入式命令行脚本中而不是仅在一个命令中设置环境变量时。
例如,如果您希望将环境变量应用于一系列串联的命令,则需要将其用引号引起来并使用 cross-env-shell
代替cross-env
。
1 | { |
经验法则是:如果要传递给cross-env
包含要解释的特殊Shell
字符的命令,请使用 cross-env-shell
。否则请坚持cross-env
。
在Windows上cross-env-shell
,如果要 在程序内部处理信号事件,则 需要使用。常见的情况是当您想要捕获SIGINT
通过Ctrl + C
在命令行界面上按调用的 事件时。