Vue中配置使用process.env詳解
vue process.env
process.env 為何物
process
是 nodejs 下的一個(gè)全局變量,它存儲(chǔ)著 nodejs 中進(jìn)程有關(guān)的信息。
言歸正傳。 process.env 是 Node.js 中的一個(gè)環(huán)境對(duì)象。其中保存著系統(tǒng)的環(huán)境的變量信息??墒褂?Node.js 命令行工具直接進(jìn)行查看。
而 NODE_ENV 就是其中的一個(gè)環(huán)境變量。這個(gè)變量主要用于標(biāo)識(shí)當(dāng)前的環(huán)境(生產(chǎn)環(huán)境,開(kāi)發(fā)環(huán)境)。默認(rèn)是沒(méi)有這個(gè)環(huán)境變量的,需要自己手動(dòng)配置。不同系統(tǒng)有不同的環(huán)境變量配置方式,在這里就不多加贅述。
NODE_ENV 與 Vue
NODE_ENV 變量只能在系統(tǒng)中配置嗎?其實(shí)不然。在 Vue 項(xiàng)目中, Vue 提供了自己的配置方式。這就要涉及到 Vue CLI 中模式的概念了。 Vue CLI 文檔說(shuō)明了這個(gè)問(wèn)題。
也就是說(shuō),在 Vue 中, NODE_ENV 可以通過(guò) .env 文件或者 .env.[mode] 文件配置。配置過(guò)后,運(yùn)行 Vue CLI 指令( npm run dev(serve) ,npm run build )時(shí),就會(huì)將該模式下的NODE_ENV載入其中了。而這些命令,都有自己的默認(rèn)模式:
- npm run dev(serve) ,其實(shí)是運(yùn)行了 vue-cli service serve ,默認(rèn)模式為 development ??梢栽?.env.development 文件下修改該模式的 NODE_ENV 。
- npm run build ,其實(shí)運(yùn)行了 vue-cli service build ,默認(rèn)模式為 production 。
可以在 .env.production 文件下修改該模式的 NODE_ENV 。
修改方式如下,以鍵值對(duì)的方式:
除了以上的修改方式外,也可以在命令后直接使用 --mode 參數(shù)手動(dòng)指定模式。當(dāng)然,每個(gè)模式配置的變量也不只有 NODE_ENV , 也可以通過(guò)配置其他的變量簡(jiǎn)化工作流程。
模式的應(yīng)用
有了模式的概念,就可以根據(jù)不同的環(huán)境配置模式,就不用每次打包時(shí)都去更改 vue.config.js 文件了。比如在測(cè)試環(huán)境和生產(chǎn)環(huán)境, publicPath參數(shù) (部署應(yīng)用包時(shí)的基本 URL) 可能不同。遇到這種情況就可以在 vue.config.js 文件中,將 publicPath 參數(shù)設(shè)置為:
publicPath: process.env.BASE_URL
設(shè)置之后,再在各個(gè) .env.[mode] 文件下對(duì) BASE_URL 進(jìn)行配置就行了,這樣就避免了每次修改配置文件的尷尬。其他的配置也是同理。
Tips: 即使不是生產(chǎn)環(huán)境,也可以將模式設(shè)置為 production ,這樣可以獲得 webpack 默認(rèn)的打包優(yōu)化。
補(bǔ)充:vue中的process.env使用
1、在nodejs中使用
1、安裝
npm install dotenv
2、根目錄下創(chuàng)建 .env 文件
HOST = localhost PORT = 8080
3、入口文件中引入 dotenv 并使用
require("dotenv").config({path: '.env'}) console.log(process.env.HOST); // localhost console.log(process.env.PORT); // 8080
2、在vue中使用
在使用腳手架創(chuàng)建項(xiàng)目的時(shí)候,會(huì)自動(dòng)安裝dotenv
,可以從package-lock.json
中找到配置
在main.js入口文件中打印
console.log(process.env);
可以看出,默認(rèn)的模式是development
即開(kāi)發(fā)模式。
模式
官網(wǎng)描述如下:https://cli.vuejs.org/zh/guide/mode-and-env.html
也就是說(shuō),在Vue
中, NODE_ENV
可以通過(guò) .env
文件或者.env.[mode]
文件配置。配置過(guò)后,運(yùn)行 Vue CLI 指令( npm run dev(serve) ,npm run build )
時(shí),就會(huì)將該模式下的NODE_ENV載入其中了。而這些命令,都有自己的默認(rèn)模式:
npm run dev(serve)
,其實(shí)是運(yùn)行了vue-cli service serve
,默認(rèn)模式為development
??梢栽?.env.development
文件下修改該模式的NODE_ENV
。npm run build
,其實(shí)運(yùn)行了vue-cli service build
,默認(rèn)模式為production
??梢栽?code> .env.production 文件下修改該模式的NODE_ENV
。
在根目錄下創(chuàng)建文件
NODE_ENV = production
注意:
只有 NODE_ENV
,BASE_URL
和以 VUE_APP_
開(kāi)頭的變量將通過(guò) webpack.DefinePlugin 靜態(tài)地嵌入到客戶(hù)端側(cè)的代碼中。這是為了避免意外公開(kāi)機(jī)器上可能具有相同名稱(chēng)的私鑰。
NODE_ENV = development VUE_APP_BASE_API = 'http://localhost:8099/'
再打印 process.env
的信息如下:
注意:.env
環(huán)境文件是通過(guò)運(yùn)行 vue-cli-service
命令載入的,因此環(huán)境文件發(fā)生變化,你需要重啟服務(wù)
。
除了以上的修改方式外,也可以在命令后直接使用--mode
參數(shù)手動(dòng)指定模式。
到此這篇關(guān)于Vue中配置process.env詳解的文章就介紹到這了,更多相關(guān)vue process.env內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vscode中使用vue的一些插件總結(jié)(方便開(kāi)發(fā))
對(duì)于很多使用vscode編寫(xiě)vue項(xiàng)目的新手同學(xué)來(lái)說(shuō),可能不知道使用什么插件,下面這篇文章主要給大家介紹了關(guān)于vscode中使用vue的一些插件,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下2022-11-11Vite?Vue3?EsLint?Prettier配置步驟極簡(jiǎn)方法詳解
這篇文章主要為大家介紹了Vite?Vue3?EsLint?Prettier配置步驟的極簡(jiǎn)方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09VUE:vuex 用戶(hù)登錄信息的數(shù)據(jù)寫(xiě)入與獲取方式
今天小編就為大家分享一篇VUE:vuex 用戶(hù)登錄信息的數(shù)據(jù)寫(xiě)入與獲取方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-11-11vue、react等單頁(yè)面項(xiàng)目部署到服務(wù)器的方法及vue和react的區(qū)別
這篇文章主要介紹了vue、react等單頁(yè)面項(xiàng)目部署到服務(wù)器的方法,需要的朋友可以參考下2018-09-09vue簡(jiǎn)單封裝axios插件和接口的統(tǒng)一管理操作示例
這篇文章主要介紹了vue簡(jiǎn)單封裝axios插件和接口的統(tǒng)一管理操作,結(jié)合具體實(shí)例形式分析了vue中axios插件安裝、配置及接口統(tǒng)一管理具體操作技巧,需要的朋友可以參考下2020-02-02Element?Table行的動(dòng)態(tài)合并及數(shù)據(jù)編輯示例
這篇文章主要為大家介紹了Element?Table行的動(dòng)態(tài)合并及數(shù)據(jù)編輯示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07Vue組件中的data必須是一個(gè)function的原因淺析
這篇文章主要介紹了Vue組件中的data必須是一個(gè)function的原因淺析,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-09-09vue elementui tree 任意級(jí)別拖拽功能代碼
這篇文章主要介紹了vue elementui tree 任意級(jí)別拖拽功能代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-08-08