当前位置:网站首页>process.env.NODE_ENV
process.env.NODE_ENV
2022-07-01 15:43:00 【黑猫几绛】
一、process.env
查阅文档的时候可以看到这样一句话:process
对象提供有关当前 Node.js 进程的信息并对其进行控制。
const process = require('node:process');
在计组的知识点中我们知道:process(进程)是系统进行资源分配和调度的基本单位,是操作系统结构的基础。那么,在node.js中,process
是否也有操作系统结构的信息呢?
打印一下看看:
const process = require('process')
const express = require('express')
const app = express()
app.get('/',(req,res)=>{
console.log(process);
})
app.listen(port, host)
访问localhost:3000
后查看控制台:
可以看到,process
代表的值是计算机系统相关的信息,而process.env
则表示的是系统环境变量。
理解:process
可以看作是node.js中的一个全局变量。
二、NODE_ENV
注意:我本来想在文档中找找这个属性的,可是它并不存在于文档中,这是因为,NODE_ENV
仅仅是一个自定义变量,据说最早是express
社区中流传这个自定义变量,后来慢慢就成为了前端开发中的一个使用规范。
注意看上面那一张图片中框起来的部分,为什么会加上这个环境变量呢?
这是因为:在开发的过程中,我们可能需要同时面临多种环境。比如:
- 开发:API_URL =Ihttp://127.0.0.1:3000
- 线上部署环境:API_URL =https://imNeko:3000
这也是为什么,有时候我们在开发的时候感觉代码项目没有问题,可是部署到线上时出现了差错。
在这里我以一个基于Nuxt.js的项目中的package.json
来举例:
"scripts": {
// 让 cross-env 把 NODE_ENV 设置为 development, 再运行指定文件 server/index.js
"dev": "cross-env NODE_ENV=development nodemon server/index.js --watch server",
"build": "nuxt build",
"start": "cross-env NODE_ENV=production node server/index.js",
"generate": "nuxt generate"
},
从上面的代码可以看出:
当我们执行npm run dev
的时候,NODE_ENV
将会被注入到 process.env
对象上,并且值为 development
,我们 只
可以在 server/index.js
脚本中以及它所引入的脚本中访问到 process.env.NODE_ENV
,而无法在其它脚本中访问
不过,如果采用的是webpack打包方式,注册下面这个插件既可以让其他文件访问到process.env.NODE_ENV
const webpack = require('webpack');
module.exports = {
// ...
plugins: [
// DefinePlugin允许我们创建全局变量,可以在编译时进行设置
new webpack.DefinePlugin({
'process.env.NODE_ENV': '"development"'
})
]
// ...
}
现在看看如何在项目中切换环境变量:
let env = process.env.NODE_ENV
let cssSourceMapDev = (env === 'development' && config.dev.cssSourceMap)
let cssSourceMapProduct = (env === 'production' && config.build.productionSourceMap)
let useCssSourceMap = cssSourceMapDev || cssSourceMapProduct
我们可以根据process.env.NODE_ENV
的值来选择编译打包什么文件。
2.1 设置NODE_ENV
2.1.1临时设置
在cmd窗口中输入这段代码:
set NODE_ENV = production
// set NODE_ENV = development
然后打印process
:
2.1.2永久设置
在系统环境变量下面手动添加即可。
边栏推荐
- swiper 轮播图,最后一张图与第一张图无缝衔接
- Advanced cross platform application development (24): uni app realizes file download and saving
- #夏日挑战赛# HarmonyOS canvas实现时钟
- 药品溯源夯实安全大堤
- Trace the source of drugs and tamp the safety dike
- Tensorflow team: we haven't been abandoned
- Pico, can we save consumer VR?
- What time do you get off work?!!!
- 硬件开发笔记(九): 硬件开发基本流程,制作一个USB转RS232的模块(八):创建asm1117-3.3V封装库并关联原理图元器件
- 《性能之巅第2版》阅读笔记(五)--file-system监测
猜你喜欢
Stm32f4-tft-spi timing logic analyzer commissioning record
[one day learning awk] function and user-defined function
【目标跟踪】|STARK
马来西亚《星报》:在WTO MC12 孙宇晨仍在坚持数字经济梦想
做空蔚来的灰熊,以“碰瓷”中概股为生?
Hardware development notes (9): basic process of hardware development, making a USB to RS232 module (8): create asm1117-3.3v package library and associate principle graphic devices
张驰咨询:锂电池导入六西格玛咨询降低电池容量衰减
自动、智能、可视!深信服SSLO方案背后的八大设计
Crypto Daily:孙宇晨在MC12上倡议用数字化技术解决全球问题
【OpenCV 例程200篇】216. 绘制多段线和多边形
随机推荐
[cloud trend] new wind direction in June! Cloud store hot list announced
GaussDB(for MySQL) :Partial Result Cache,通过缓存中间结果对算子进行加速
RT-Thread Env 工具介绍(学习笔记)
[target tracking] |stark
Qt+pcl Chapter 6 point cloud registration ICP Series 2
6.2 normalization 6.2.6 BC normal form (BCNF) 6.2.9 normalization summary
Zhang Chi Consulting: lead lithium battery into six sigma consulting to reduce battery capacity attenuation
自动、智能、可视!深信服SSLO方案背后的八大设计
Advanced cross platform application development (24): uni app realizes file download and saving
[200 opencv routines] 216 Draw polylines and polygons
Pocket Network为Moonbeam和Moonriver RPC层提供支持
ATSs: automatically select samples to eliminate the difference between anchor based and anchor free object detection methods
使用swiper制作手机端轮播图
摩根大通期货开户安全吗?摩根大通期货公司开户方法是什么?
求求你们,别再刷 Star 了!这跟“爱国”没关系!
Survey of intrusion detection systems:techniques, datasets and challenges
One revolution, two forces, three links: the "carbon reduction" roadmap behind the industrial energy efficiency improvement action plan
[Cloudera][ImpalaJDBCDriver](500164)Error initialized or created transport for authentication
Reading notes of top performance version 2 (V) -- file system monitoring
ThinkPHP进阶