首页 > 编程语言 >使用process.env.NODE_ENV的正确姿势

使用process.env.NODE_ENV的正确姿势

时间:2022-09-29 16:47:45浏览次数:79  
标签:NODE env process cross webpack ENV

什么是process.env.NODE_ENV

process.env.NODE_ENV应该是我们最熟悉的环境变量了,它经常出现在使用框架或者类库的时候,被用来区分不同的环境(开发,测试,生产等),以便我们进行相对应的项目配置,比如是否开启sourceMap,api地址切换等。那为什么process.env.NODE_ENV能用来区分环境呢?它是如何来的?

先来看一下processprocess.env的官方解释:

  • process

process 对象是一个 global (全局变量),提供有关信息,控制当前 Node.js 进程。作为一个对象,它对于 Node.js 应用程序始终是可用的,故无需使用 require()

  • process.env

process.env属性返回一个包含用户环境信息的对象。

在node环境中,当我们打印process.env时,发现它并没有NODE_ENV这一个属性。实际上,process.env.NODE_ENV是在package.json的scripts命令中注入的,也就是NODE_ENV并不是node自带的,而是由用户定义的,至于为什么叫NODE_ENV,应该是约定成俗的吧。

{
  "scripts": {
    "dev": "NODE_ENV=development webpack --config webpack.dev.config.js"
  }
}

可以看到NODE_ENV被赋值为development,当执行npm run dev时,我们就可以在 webpack.dev.config.js脚本中以及它所引入的脚本中访问到process.env.NODE_ENV,而无法在其它脚本中访问。

如何在其他脚本中访问

前面提到,在scripts命令中注入的NODE_ENV只能被webpack的构建脚本访问,而被webpack打包的源码中是无法访问到的,此时可以借助webpack的DefinePlugin插件,创建全局变量。

const webpack = require('webpack');
module.exports = {
  plugins: [
    new webpack.DefinePlugin({
      'process.env.NODE_ENV': '"development"'
    })
  ]
}

当然DefinePlugin不仅仅可以定义process.env.NODE_ENV,你也可以根据自己的需要定义其他的全局变量。定义完成之后,就可以在项目代码中直接使用了。

跨平台的cross-env

在window平台下直接设置NODE_ENV =XXX是会报错的,cross-env 能够提供一个设置环境变量的scripts,这样我们就能够以unix方式设置环境变量,然后在windows上也能够兼容。

  1. 安装cross-env
npm install cross-env --save
  1. NODE_ENV=XXX前面添加cross-env
    "scripts": {
      "dev": "cross-env NODE_ENV=development webpack-dev-server"
    }

使用.env文件

如果需要配置的环境变量太多,全部设置在scripts命令中既不美观也不容易维护,此时将环境变量配置在.env文件中,然后使用dotenv插件来加载.env配置文件。

  1. 安装dotenv
npm install dotenv --save
  1. 创建.env文件
NODE_ENV = development
# 这是注释
API_URL = https://abc.com
  1. 尽早的在程序中引入和配置dotenv。在config函数中可以配置.env文件的路径。具体参考dotenv文档
require('dotenv').config()
这样就可以在程序中使用环境变量了。

在实际项目中,我们一般还是在scripts命令中设置NODE_ENV,然后通过不同的NODE_ENV来加载不同的.env文件。

举个例子:

有一个项目,简单的项目结构如下:

├── env
   ├── .env.dev
   ├── .env.test
   ├── .env.pre
   └── .env.prd
├── webpack.config.js

.env.***文件中配置了每个环境对应的变量,例如:

# .env.test 文件
API_URL = https://abc-test.com

# .env.pre 文件
API_URL = https://abc-pre.com

# .env.prd 文件
API_URL = https://abc.com

webpack.config.js加载env配置:

require('dotenv').config({ path: path.resolve(__dirname, './env/.env.' + process.env.NODE_ENV) })

最后别忘了还要在scripts命令中设置NODE_ENV

# dev
cross-env NODE_ENV=dev

# test
cross-env NODE_ENV=test

# pre
cross-env NODE_ENV=pre

# prd
cross-env NODE_ENV=prd

Vue cli 也可以加载.env文件,详情可查看:Vue cli-环境变量和模式



标签:NODE,env,process,cross,webpack,ENV
From: https://www.cnblogs.com/ysx215/p/16742049.html

相关文章

  • 同时启动node和vue项目解决方案
    前言自己写的前端项目是vue做前端页面,node做后端接口,但是每次启动都要分开打两次启动命令,感觉很不智能,于是决定用一个命令让项目同时启动vue和node说干就干。。。技术......
  • 多进程multiprocessing
    多进程实现简易版的抢票工具实现:多个进程共享同一文件,把文件当数据库,用多个进程模拟多个人执行抢票任务关键词:多进程,锁1)多进程importjsonimportosimporttimefro......
  • debian/ubuntu下安装nodejs npm
    wgethttps://nodejs.org/dist/v16.17.1/node-v16.17.1-linux-x64.tar.xz nodejs官网下载地址,目前最新版,以后有更新就换新的地址,wget下来,解压tar-xvfnode-v16.17.1-li......
  • nodejs stream 背压处理学习
    内容是nodejs官方的,对于需要开发自己的stream是很值得学习参考的参考资料​​https://nodejs.org/en/docs/guides/backpressuring-in-streams/​​​​https://nodejs.org......
  • How to Set Up a Virtual Environment in Python – And Why It's Useful
    https://www.freecodecamp.org/news/how-to-setup-virtual-environments-in-python/HowtoSetUpaVirtualEnvironmentinPython–AndWhyIt'sUsefulStephenSan......
  • Remote 'AttachHome' failed on nodes: 'xxxxx'
    系统:CentOS7.964位数据库:11.2.0.364位环境:RAC(双节点)问题描述:由于第一次安装rac失败,此后清空节点1/u01/app/oraInventory目录下的全部文件后重新安装rac,进度到达76%报......
  • jmeter BeanShell PostProcessor 获取http请求的response出参,存入CSV
    importorg.json.*;Stringresponse=prev.getResponseDataAsString();JSONObjectdata_obj=newJSONObject(response);Stringdata_1=data_obj.get("data").toString()......
  • Kubernetes小技巧关于节点pod ip node数量规划
    背景:最近就想体验各种多集群互联(基于wireguard),然后就深感网络划分的重要性,开始网络设计的杂七乱八的。想互联了都各种问题了,网络重叠了怎么办?集群扩容IP资源不够了杂整?还有......
  • asdf 安装 python 与 nodejs
    asdf安装python与nodejs系统centos7.9安装asdf官方地址:asdf-vm/asdf:ExtendableversionmanagerwithsupportforRuby,Node.js,Elixir,Erlang&more(gi......
  • 用 nodejs 搭建脚手架
    1前言1.1像我们熟悉的vue-cli,taro-cli等脚手架,只需要输入简单的命令taroinitproject,即可快速帮我们生成一个初始项目。在日常开发中,有一个脚手架工具可以用来提高工......