admin管理员组

文章数量:1794759

环境变量process.env.NODE

环境变量process.env.NODE

process.env.NODE_ENV详解

前几天一个月薪35k的兄弟,给我推了一个人工智能学习网站,看了一段时间挺有意思的。包括语音识别、机器翻译等从基础到实战都有,很详细,分享给大家。

一、 process.env.NODE_ENV是什么?

在node中,有全局变量process表示的是当前的node进程。

process.env包含着关于系统环境的信,但是process.env中并不存在NODE_ENV。

NODE_ENV是一个用户自定义的变量,在webpack中它的用途是判断生产环境或开发环境。

例如:

process.env.NODE_ENV === "development" ? "测试/开发地址" : "生产环境地址"

通过环境变量来区分开发环境还是生产环境,当目前处于开发环境,环境变量为development;如果当前环境是生产环境,环境变量是production。提出来封装,抛出对应环境的服务。

可以在axios创建实例的时候,把这个baseUrl导入,使用。

import baseUrl from './config' const service = axios.create({ baseUrl, // 设置全局基地址 timeOut: 5000, // 设置超时时间 })

如果我想在vue.config.js中动态设置反向代理

devServer: { proxy: { // 反向代理 '/api': { target: process.env.VUE_APP_BASE_API, pathRewrite: { '^/api': '' }, logLevel: 'debug', // 可以在终端窗口看到真实代理地址 } } }

Vue配置环境变量 原来是这么使用的呀

Vue配置多环境变量,原来是这么回事啊

为了查看 process的基本信,我们可以在文件夹中 新建一个process.js文件,在里面加一句代码console.log(process);然后进入该文件夹,执行node process.js可以在命令行中打印如下信:

$ node process.js process { title: 'node', version: 'v4.4.4', moduleLoadList: [....], versions: { http_parser: '2.5.2', node: '4.4.4', v8: '4.5.103.35', uv: '1.8.0', zlib: '1.2.8', ares: '1.10.1-DEV', icu: '56.1', modules: '46', openssl: '1.0.2h' }, arch: 'x64', platform: 'darwin', release: { name: 'node', lts: 'Argon', sourceUrl: 'nodejs/download/release/v4.4.4/node-v4.4.4.tar.gz', headersUrl: 'nodejs/download/release/v4.4.4/node-v4.4.4-headers.tar.gz' }, argv: [ '/Users/tugenhua/.nvm/versions/node/v4.4.4/bin/node', '/Users/tugenhua/个人demo/process.js' ], execArgv: [], env: { TERM_PROGRAM: 'Apple_Terminal', SHELL: '/bin/zsh', TERM: 'xterm-256color', TMPDIR: '/var/folders/l7/zndlx1qs05v29pjhvkgpmhjm0000gn/T/', Apple_PubSub_Socket_Render: '/private/tmp/com.apple.launchd.7Ax4C1EWMx/Render', TERM_PROGRAM_VERSION: '404', TERM_SESSION_ID: '82E05668-442D-4180-ADA3-8CF64D85E5A9', USER: 'tugenhua', SSH_AUTH_SOCK: '/private/tmp/com.apple.launchd.MYOMheYcL3/Listeners', PATH: '/Users/tugenhua/.nvm/versions/node/v4.4.4/bin:/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin', PWD: '/Users/tugenhua/个人demo', LANG: 'zh_CN.UTF-8', XPC_FLAGS: '0x0', XPC_SERVICE_NAME: '0', SHLVL: '1', HOME: '/Users/tugenhua', LOGNAME: 'tugenhua', SECURITYSESSIONID: '186a8', OLDPWD: '/Users/tugenhua/工作文档/sns_pc', ZSH: '/Users/tugenhua/.oh-my-zsh', PAGER: 'less', LESS: '-R', LC_CTYPE: 'zh_CN.UTF-8', LSCOLORS: 'Gxfxcxdxbxegedabagacad', NVM_DIR: '/Users/tugenhua/.nvm', NVM_NODEJS_ORG_MIRROR: 'nodejs/dist', NVM_IOJS_ORG_MIRROR: 'iojs/dist', NVM_RC_VERSION: '', MANPATH: '/Users/tugenhua/.nvm/versions/node/v4.4.4/share/man:/usr/local/share/man:/usr/share/man:/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/usr/share/man:/Applications/Xcode.app/Contents/Developer/usr/share/man:/Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/share/man', NVM_PATH: '/Users/tugenhua/.nvm/versions/node/v4.4.4/lib/node', NVM_BIN: '/Users/tugenhua/.nvm/versions/node/v4.4.4/bin', _: '/Users/tugenhua/.nvm/versions/node/v4.4.4/bin/node', __CF_USER_TEXT_ENCODING: '0x1F5:0x19:0x34' }, pid: 14034, features: { debug: false, uv: true, ipv6: true, tls_npn: true, tls_sni: true, tls_ocsp: true, tls: true }, _needImmediateCallback: false, config: {}, nextTick: [Function: nextTick], _tickCallback: [Function: _tickCallback], _tickDomainCallback: [Function: _tickDomainCallback], stdout: [Getter], stderr: [Getter], stdin: [Getter], openStdin: [Function], exit: [Function], kill: [Function], mainModule: Module { id: '.', exports: {}, parent: null, filename: '/Users/tugenhua/个人demo/process.js', loaded: false, children: [], paths: [ '/Users/tugenhua/个人demo/node_modules', '/Users/tugenhua/node_modules', '/Users/node_modules', '/node_modules' ] } }

如上就可以看到 process是node的全局变量,并且process有env这个属性,但是没有NODE_ENV这个属性。

二、process.env.NODE_ENV该如何配置?

process.env属性返回的是一个包含用户环境信的对象,它可以区分开发环境或正式环境的依据,那么我们如何配置它呢?

方法1:配置环境变量
  • windows环境配置如下:
#node中常用的到的环境变量是NODE_ENV,首先查看是否存在 set NODE_ENV #如果不存在则添加环境变量 set NODE_ENV=production #环境变量追加值 set 变量名=%变量名%;变量内容 set path=%path%;C:\\web;C:\\Tools #某些时候需要删除环境变量 set NODE_ENV=
  • Linux配置(mac系统环境也属于这个)如下:
#node中常用的到的环境变量是NODE_ENV,首先查看是否存在 echo $NODE_ENV #如果不存在则添加环境变量 export NODE_ENV=production #环境变量追加值 export path=$path:/home/download:/usr/local/ #某些时候需要删除环境变量 unset NODE_ENV #某些时候需要显示所有的环境变量 env

如下查看环境变量,添加环境变量,删除环境变量操作如下:

注意:如果NODE_ENV设置为production后,所有的项目都会处于正式环境中。 此时使用命令npm install下载依赖包时,只会把package.json中的dependencies依赖项下载下来,对于devDependencies中的依赖包是下载不下来的。因此需要使用上面的命令unset NODE_ENV删除刚刚设置的环境变量。

方法2:使用DefinePlugin

DefinePlugin官网的解释是:DefinePlugin允许我们创建全局变量,可以在编译时进行设置。

因此可以使用该属性来设置全局变量来区分开发环境和正式环境,这就是DefinePlugin的基本功能。

我们可以在webpack.config.js中添加如下代码配置全局变量信,因为当webpack进行编译的时候会全局设置变量,如下代码:

module.exports = { plugins: [ // 设置环境变量信 new webpack.DefinePlugin({ PRODUCTION: JSON.stringify(true), VERSION: JSON.stringify('5fa3b9'), BROWSER_SUPPORTS_HTML5: true, TWO: '1+1', 'typeof window': JSON.stringify('object'), 'process.env': { NODE_ENV: JSON.stringify(process.env.NODE_ENV) } }) ] }

package.json中的打包配置如下:

"scripts": { "dev": "NODE_ENV=development webpack-dev-server --progress --colors --devtool cheap-module-eval-source-map --hot --inline", "build": "NODE_ENV=production webpack --progress --colors --devtool cheap-module-source-map", "build:dll": "webpack --config webpack.dll.config.js" },

这样配置完成后,为了验证一下是否是全局变量,运行npm run dev打包后,在我们项目入口js文件中打印下即可:

console.log(process.env.NODE_ENV); // 打印结果为 'development'

发现process.env.NODE_ENV已经被作为全局变量打印出来了,因此在项目打包中为了区分开发环境和正式环境我们可以使用这种方法。

关于cross-env
  • 什么是cross-env呢? 它是运行跨平台设置和使用环境变量的脚本。

  • 它的作用是啥? 当我们使用DefinePlugin这种方法设置NODE_ENV时,大多数windows命令会提示将会阻塞或者异常,或者windows不支持NODE_ENV=development的这样的设置方式,会报错。因此cross-env出现了。我们可以使用cross-env命令来实现全开发平台的兼容。 要使用该命令的话,我们首先需要在我们的项目中安装该命令:

npm install --save-dev cross-env

在package.json中的scripts命令如下:

"scripts": { "dev": "cross-env NODE_ENV=development webpack-dev-server --progress --colors --devtool cheap-module-eval-source-map --hot --inline", "build": "cross-env NODE_ENV=production webpack --progress --colors --devtool cheap-module-source-map", "build:dll": "webpack --config webpack.dll.config.js" } 三、vue-cli3.0中的process.env.NODE_ENV

使用vue-cli3构建的项目就简单多了,因为vue-cli3使用上述的DefinePlugin方式帮你把process.env.NODE_ENV配置好了,我们不需要再自己去配置。

它自带了三种模式:

  • development:在vue-cli-service serve下,即开发环境使用
  • production:在vue-cli-service build和vue-cli-service test:e2e下,即正式环境使用
  • test: 在vue-cli-service test:unit下使用

在package.json中的scripts命令如下

{ "name": "", "version": "0.1.0", "private": true, "scripts": { "dev": "vue-cli-service serve", //本地开发运行,会把process.env.NODE_ENV设置为'development' "build": "vue-cli-service build", //默认打包模式,会把process.env.NODE_ENV设置为'production' }, "dependencies": { } }

参考: process.env.NODE_ENV详解 理解webpack之process.env.NODE_ENV详解(十八) 根据process.env.NODE_ENV配置本地/测试/生产环境的接口请求地址

本文标签: 环境变量PROCESSnodeenv