process.env.NODE_ENV詳解

一屉佳、 process.env.NODE_ENV是什么谷朝?

在node中茫经,有全局變量process表示的是當(dāng)前的node進(jìn)程蒸眠。
process.env包含著關(guān)于系統(tǒng)環(huán)境的信息短纵,但是process.env中并不存在NODE_ENV這個(gè)東西。

NODE_ENV是一個(gè)用戶自定義的變量体箕,在webpack中它的用途是判斷生產(chǎn)環(huán)境或開(kāi)發(fā)環(huán)境

為了查看 process的基本信息挑童,我們可以在文件夾中 新建一個(gè)process.js文件累铅,在里面加一句代碼console.log(process);然后進(jìn)入該文件夾,執(zhí)行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: 'https://nodejs.org/download/release/v4.4.4/node-v4.4.4.tar.gz',
     headersUrl: 'https://nodejs.org/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/個(gè)人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/個(gè)人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: 'https://nodejs.org/dist',
     NVM_IOJS_ORG_MIRROR: 'https://iojs.org/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/個(gè)人demo/process.js',
     loaded: false,
     children: [],
     paths: 
      [ '/Users/tugenhua/個(gè)人demo/node_modules',
        '/Users/tugenhua/node_modules',
        '/Users/node_modules',
        '/node_modules' ] } }

如上就可以看到 process是node的全局變量站叼,并且process有env這個(gè)屬性娃兽,但是沒(méi)有NODE_ENV這個(gè)屬性。

二尽楔、process.env.NODE_ENV該如何配置投储?

process.env屬性返回的是一個(gè)包含用戶環(huán)境信息的對(duì)象,它可以區(qū)分開(kāi)發(fā)環(huán)境或正式環(huán)境的依據(jù)阔馋,那么我們?nèi)绾闻渲盟兀?/p>

方法1:配置環(huán)境變量

  • windows環(huán)境配置如下:
#node中常用的到的環(huán)境變量是NODE_ENV玛荞,首先查看是否存在 
set NODE_ENV 

#如果不存在則添加環(huán)境變量 
set NODE_ENV=production 

#環(huán)境變量追加值 set 變量名=%變量名%;變量?jī)?nèi)容 
set path=%path%;C:\web;C:\Tools 

#某些時(shí)候需要?jiǎng)h除環(huán)境變量 
set NODE_ENV=
  • Linux配置(mac系統(tǒng)環(huán)境也屬于這個(gè))如下:
#node中常用的到的環(huán)境變量是NODE_ENV,首先查看是否存在
echo $NODE_ENV

#如果不存在則添加環(huán)境變量
export NODE_ENV=production

#環(huán)境變量追加值
export path=$path:/home/download:/usr/local/

#某些時(shí)候需要?jiǎng)h除環(huán)境變量
unset NODE_ENV

#某些時(shí)候需要顯示所有的環(huán)境變量
env

注意:如果NODE_ENV設(shè)置為production后呕寝,所有的項(xiàng)目都會(huì)處于正式環(huán)境中勋眯。
此時(shí)使用命令npm install下載依賴(lài)包時(shí),只會(huì)把package.json中的dependencies依賴(lài)項(xiàng)下載下來(lái),對(duì)于devDependencies中的依賴(lài)包是下載不下來(lái)的客蹋。因此需要使用上面的命令unset NODE_ENV刪除剛剛設(shè)置的環(huán)境變量塞蹭。

方法2:使用DefinePlugin

DefinePlugin官網(wǎng)的解釋是:DefinePlugin允許我們創(chuàng)建全局變量,可以在編譯時(shí)進(jìn)行設(shè)置嚼酝。

因此可以使用該屬性來(lái)設(shè)置全局變量來(lái)區(qū)分開(kāi)發(fā)環(huán)境和正式環(huán)境浮还,這就是DefinePlugin的基本功能。

我們可以在webpack.config.js中添加如下代碼配置全局變量信息闽巩,因?yàn)楫?dāng)webpack進(jìn)行編譯的時(shí)候會(huì)全局設(shè)置變量钧舌,如下代碼:

module.exports = {
  plugins: [
    // 設(shè)置環(huán)境變量信息
    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"
},

這樣配置完成后,為了驗(yàn)證一下是否是全局變量涎跨,運(yùn)行npm run dev打包后洼冻,在我們項(xiàng)目入口js文件中打印下即可:

console.log(process.env.NODE_ENV); // 打印結(jié)果為 'development' 

發(fā)現(xiàn)process.env.NODE_ENV已經(jīng)被作為全局變量打印出來(lái)了,因此在項(xiàng)目打包中為了區(qū)分開(kāi)發(fā)環(huán)境和正式環(huán)境我們可以使用這種方法隅很。

關(guān)于cross-env

  • 什么是cross-env呢撞牢?
    它是運(yùn)行跨平臺(tái)設(shè)置和使用環(huán)境變量的腳本。

  • 它的作用是啥叔营?
    當(dāng)我們使用DefinePlugin這種方法設(shè)置NODE_ENV時(shí)屋彪,大多數(shù)windows命令會(huì)提示將會(huì)阻塞或者異常,或者windows不支持NODE_ENV=development的這樣的設(shè)置方式绒尊,會(huì)報(bào)錯(cuò)畜挥。因此cross-env出現(xiàn)了。我們可以使用cross-env命令來(lái)實(shí)現(xiàn)全開(kāi)發(fā)平臺(tái)的兼容婴谱。
    要使用該命令的話蟹但,我們首先需要在我們的項(xiàng)目中安裝該命令:

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構(gòu)建的項(xiàng)目就簡(jiǎn)單多了谭羔,因?yàn)関ue-cli3使用上述的DefinePlugin方式幫你把process.env.NODE_ENV配置好了华糖,我們不需要再自己去配置。
它自帶了三種模式:

development:在vue-cli-service serve下瘟裸,即開(kāi)發(fā)環(huán)境使用
production:在vue-cli-service build和vue-cli-service test:e2e下客叉,即正式環(huán)境使用
test: 在vue-cli-service test:unit下使用

在package.json中的scripts命令如下

{
  "name": "",
  "version": "0.1.0",
  "private": true,
  "scripts": {
    "dev": "vue-cli-service serve", //本地開(kāi)發(fā)運(yùn)行,會(huì)把process.env.NODE_ENV設(shè)置為'development'
    "build": "vue-cli-service build", //默認(rèn)打包模式话告,會(huì)把process.env.NODE_ENV設(shè)置為'production'
  },
  "dependencies": {
  }
}

參考自:https://www.cnblogs.com/tugenhua0707/p/9780621.html

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末兼搏,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子超棺,更是在濱河造成了極大的恐慌向族,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,542評(píng)論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件棠绘,死亡現(xiàn)場(chǎng)離奇詭異件相,居然都是意外死亡再扭,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,822評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門(mén)夜矗,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)泛范,“玉大人,你說(shuō)我怎么就攤上這事紊撕“盏矗” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,912評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵对扶,是天一觀的道長(zhǎng)区赵。 經(jīng)常有香客問(wèn)我,道長(zhǎng)浪南,這世上最難降的妖魔是什么笼才? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,449評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮络凿,結(jié)果婚禮上骡送,老公的妹妹穿的比我還像新娘。我一直安慰自己絮记,他們只是感情好摔踱,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,500評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著怨愤,像睡著了一般派敷。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上憔四,一...
    開(kāi)封第一講書(shū)人閱讀 51,370評(píng)論 1 302
  • 那天膀息,我揣著相機(jī)與錄音般眉,去河邊找鬼了赵。 笑死,一個(gè)胖子當(dāng)著我的面吹牛甸赃,可吹牛的內(nèi)容都是我干的柿汛。 我是一名探鬼主播,決...
    沈念sama閱讀 40,193評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼埠对,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼络断!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起项玛,我...
    開(kāi)封第一講書(shū)人閱讀 39,074評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤貌笨,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后襟沮,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體锥惋,經(jīng)...
    沈念sama閱讀 45,505評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡昌腰,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,722評(píng)論 3 335
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了膀跌。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片遭商。...
    茶點(diǎn)故事閱讀 39,841評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖捅伤,靈堂內(nèi)的尸體忽然破棺而出劫流,到底是詐尸還是另有隱情,我是刑警寧澤丛忆,帶...
    沈念sama閱讀 35,569評(píng)論 5 345
  • 正文 年R本政府宣布祠汇,位于F島的核電站,受9級(jí)特大地震影響熄诡,放射性物質(zhì)發(fā)生泄漏座哩。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,168評(píng)論 3 328
  • 文/蒙蒙 一粮彤、第九天 我趴在偏房一處隱蔽的房頂上張望根穷。 院中可真熱鬧,春花似錦导坟、人聲如沸屿良。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,783評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)尘惧。三九已至,卻和暖如春递递,著一層夾襖步出監(jiān)牢的瞬間喷橙,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,918評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工登舞, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留贰逾,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,962評(píng)論 2 370
  • 正文 我出身青樓菠秒,卻偏偏與公主長(zhǎng)得像疙剑,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子践叠,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,781評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容