在很多前端项目中都需要配置node的环境变量,通常在package.json的scripts命令内容和webpack配置文件中可以看到NODE_ENV这个变量,值一般为production或者product,也有人简写为'dev'或'prod'。
1.NODE_ENV的作用
通常这个变量用来区分开发与生产环境,加载不同的配置。
2.配置
node中有全局变量process表示当前node进程,process.env包含着关于系统环境的信息。但是process.env中并不存在NODE_ENV这个东西,NODE_ENV只是一个用户自定义的变量,当我们在服务启动时配置NODE_ENV,或在代码中给process.env.NODE_ENV赋值,js便能通过process.env.NODE_ENV获取信息。
通常可以在package.json的scripts里设置
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1",
"start": "SET NODE_ENV=production node index.js"
},
一般也可以在webpack配置文件中对NODE_ENV作默认处理
NODE_ENV: process.env.NODE_ENV || 'development',
3.不同平台下的设置
在类unix系统和安装并使用了bash的windows的系统上:
"EXPORT NODE_ENV=production && webpack --config build/webpack.config.js"
在windows系统上:
"SET NODE_ENV=production && webpack --config build/webpack.config.js"
还可以引用第三方插件cross-env,兼容win和linux
"scripts": {
"start": "cross-env NODE_ENV=production node index.js"
}
需要注意的是使用cross-env中间不能有&&,&&这样会划分出前后两个环境,导致后一个语句的环境没有NODE_ENV
网友评论