今天在看别人的代码的时候,看到如下代码:
image.png

不太了解process.env.NODE_ENV是什么,也没看到有从哪里引进来,于是百度一下才知道:

它属于node中的,在node中,有全局变量process表示的是当前的node进程。process.env包含着关于系统环境的信息。但是process.env中并不存在NODE_ENV这个东西。NODE_ENV是用户一个自定义的变量,在webpack中它的用途是判断生产环境或开发环境的依据的。

如果想查看process的基本信息,可在文件夹中新建一个process.js文件,并在里面console.log(process),然后进入该文件夹打开cmd并执行node process.js运行,打印信息如下:

  1. $ node process.js
  2. process {
  3. title: 'node',
  4. version: 'v4.4.4',
  5. moduleLoadList:
  6. [....],
  7. versions:
  8. { http_parser: '2.5.2',
  9. node: '4.4.4',
  10. v8: '4.5.103.35',
  11. uv: '1.8.0',
  12. zlib: '1.2.8',
  13. ares: '1.10.1-DEV',
  14. icu: '56.1',
  15. modules: '46',
  16. openssl: '1.0.2h' },
  17. arch: 'x64',
  18. platform: 'darwin',
  19. release:
  20. { name: 'node',
  21. lts: 'Argon',
  22. sourceUrl: 'https://nodejs.org/download/release/v4.4.4/node-v4.4.4.tar.gz',
  23. headersUrl: 'https://nodejs.org/download/release/v4.4.4/node-v4.4.4-headers.tar.gz' },
  24. argv:
  25. [ '/Users/tugenhua/.nvm/versions/node/v4.4.4/bin/node',
  26. '/Users/tugenhua/个人demo/process.js' ],
  27. execArgv: [],
  28. env:
  29. { TERM_PROGRAM: 'Apple_Terminal',
  30. SHELL: '/bin/zsh',
  31. TERM: 'xterm-256color',
  32. TMPDIR: '/var/folders/l7/zndlx1qs05v29pjhvkgpmhjm0000gn/T/',
  33. Apple_PubSub_Socket_Render: '/private/tmp/com.apple.launchd.7Ax4C1EWMx/Render',
  34. TERM_PROGRAM_VERSION: '404',
  35. TERM_SESSION_ID: '82E05668-442D-4180-ADA3-8CF64D85E5A9',
  36. USER: 'tugenhua',
  37. SSH_AUTH_SOCK: '/private/tmp/com.apple.launchd.MYOMheYcL3/Listeners',
  38. PATH: '/Users/tugenhua/.nvm/versions/node/v4.4.4/bin:/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin',
  39. PWD: '/Users/tugenhua/个人demo',
  40. LANG: 'zh_CN.UTF-8',
  41. XPC_FLAGS: '0x0',
  42. XPC_SERVICE_NAME: '0',
  43. SHLVL: '1',
  44. HOME: '/Users/tugenhua',
  45. LOGNAME: 'tugenhua',
  46. SECURITYSESSIONID: '186a8',
  47. OLDPWD: '/Users/tugenhua/工作文档/sns_pc',
  48. ZSH: '/Users/tugenhua/.oh-my-zsh',
  49. PAGER: 'less',
  50. LESS: '-R',
  51. LC_CTYPE: 'zh_CN.UTF-8',
  52. LSCOLORS: 'Gxfxcxdxbxegedabagacad',
  53. NVM_DIR: '/Users/tugenhua/.nvm',
  54. NVM_NODEJS_ORG_MIRROR: 'https://nodejs.org/dist',
  55. NVM_IOJS_ORG_MIRROR: 'https://iojs.org/dist',
  56. NVM_RC_VERSION: '',
  57. 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',
  58. NVM_PATH: '/Users/tugenhua/.nvm/versions/node/v4.4.4/lib/node',
  59. NVM_BIN: '/Users/tugenhua/.nvm/versions/node/v4.4.4/bin',
  60. _: '/Users/tugenhua/.nvm/versions/node/v4.4.4/bin/node',
  61. __CF_USER_TEXT_ENCODING: '0x1F5:0x19:0x34' },
  62. pid: 14034,
  63. features:
  64. { debug: false,
  65. uv: true,
  66. ipv6: true,
  67. tls_npn: true,
  68. tls_sni: true,
  69. tls_ocsp: true,
  70. tls: true },
  71. _needImmediateCallback: false,
  72. config: {},
  73. nextTick: [Function: nextTick],
  74. _tickCallback: [Function: _tickCallback],
  75. _tickDomainCallback: [Function: _tickDomainCallback],
  76. stdout: [Getter],
  77. stderr: [Getter],
  78. stdin: [Getter],
  79. openStdin: [Function],
  80. exit: [Function],
  81. kill: [Function],
  82. mainModule:
  83. Module {
  84. id: '.',
  85. exports: {},
  86. parent: null,
  87. filename: '/Users/tugenhua/个人demo/process.js',
  88. loaded: false,
  89. children: [],
  90. paths:
  91. [ '/Users/tugenhua/个人demo/node_modules',
  92. '/Users/tugenhua/node_modules',
  93. '/Users/node_modules',
  94. '/node_modules' ] } }

可以看到process是node的全局变量,并且process有env这个属性,但是没有NODE_ENV这个属性。
process.env属性返回的是一个包含用户环境信息的对象,它可以作为区分开发环境或正式环境的依据。那我们应该如何配置环境变量呢?

配置环境变量的方法:

可直接在cmd环境里配置,查看环境变量,添加环境变量,删除环境变量等操作。

windows环境配置如下:

  1. #node中常用的到的环境变量是NODE_ENV,首先查看是否存在
  2. set NODE_ENV
  3. #如果不存在则添加环境变量
  4. set NODE_ENV=production
  5. #环境变量追加值 set 变量名=%变量名%;变量内容
  6. set path=%path%;C:\web;C:\Tools
  7. #某些时候需要删除环境变量
  8. set NODE_ENV=

Linux配置(mac系统环境也属于这个):

  1. #node中常用的到的环境变量是NODE_ENV,首先查看是否存在
  2. echo $NODE_ENV
  3. #如果不存在则添加环境变量
  4. export NODE_ENV=production
  5. #环境变量追加值
  6. export path=$path:/home/download:/usr/local/
  7. #某些时候需要删除环境变量
  8. unset NODE_ENV
  9. #某些时候需要显示所有的环境变量
  10. env

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


参考自这里