欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue-cli3環(huán)境變量與分環(huán)境打包的方法示例

 更新時(shí)間:2019年02月18日 14:36:36   作者:yunsiyu  
這篇文章主要介紹了vue-cli3環(huán)境變量與分環(huán)境打包的方法示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

第一步 : 了解環(huán)境變量概念

我們可以根目錄中的下列文件來指定環(huán)境變量:

.env        # 在所有的環(huán)境中被載入
.env.local     # 在所有的環(huán)境中被載入,但會(huì)被 git 忽略
.env.[mode]     # 只在指定的模式中被載入
.env.[mode].local  # 只在指定的模式中被載入,但會(huì)被 git 忽略

環(huán)境變量文件只包含環(huán)境變量的“鍵=值”對(duì):

FOO=bar
VUE_APP_SECRET=secret // 只有VUE_APP_開頭的環(huán)境變量可以在項(xiàng)目代碼中直接使用

除了 自定義的VUE_APP_* 變量之外,在你的應(yīng)用代碼中始終可用的還有兩個(gè)特殊的變量:

  • NODE_ENV - 會(huì)是 "development"、"production" 或 "test"中的一個(gè)。具體的值取決于應(yīng)用運(yùn)行的模式。
  • BASE_URL - 會(huì)和 vue.config.js 中的 publicPath 選項(xiàng)相符,即你的應(yīng)用會(huì)部署到的基礎(chǔ)路徑。

為一個(gè)特定模式準(zhǔn)備的環(huán)境文件的 (例如 .env.production) 將會(huì)比一般的環(huán)境文件 (例如 .env) 擁有更高的優(yōu)先級(jí)。

模式概念:

模式是 Vue CLI 項(xiàng)目中一個(gè)重要的概念。一般情況下 Vue CLI 項(xiàng)目有三個(gè)默認(rèn)模式:

  • development 模式用于 vue-cli-service serve
  • production 模式用于 vue-cli-service build 和 vue-cli-service test:e2e
  • test 模式用于 vue-cli-service test:unit

模式不等同于 NODE_ENV,一個(gè)模式可以包含多個(gè)環(huán)境變量。也就是說,每個(gè)模式都將 NODE_ENV的值設(shè)置為模式的名稱(可重新賦值更改)——比如在 development 模式下 NODE_ENV 的值會(huì)被設(shè)置為 "development"。

你可以通過為 .env 文件增加后綴來設(shè)置某個(gè)模式下特有的環(huán)境變量。比如,如果你在項(xiàng)目根目錄創(chuàng)建一個(gè)名為 .env.development 的文件,那么在這個(gè)文件里聲明過的變量就只會(huì)在 development 模式下被載入。

你可以通過傳遞 --mode 選項(xiàng)參數(shù)為命令行覆寫默認(rèn)的模式。例如,如果你想要在構(gòu)建命令中使用開發(fā)環(huán)境變量,請(qǐng)?jiān)谀愕?package.json 腳本中加入:

"dev-build": "vue-cli-service build --mode development",

環(huán)境變量的使用 :

只有以 VUE_APP_ 開頭的變量會(huì)被 webpack.DefinePlugin 靜態(tài)嵌入到客戶端側(cè)的包中(即在項(xiàng)目代碼中使用)。你可以在應(yīng)用的代碼中這樣訪問它們:

console.log(process.env.VUE_APP_SECRET)

理解指令 , 模式 , 環(huán)境變量之間的關(guān)系

我們?cè)陧?xiàng)目中的package.json經(jīng)常能看見以下這樣的指令

在一個(gè) Vue CLI 項(xiàng)目中,@vue/cli-service 安裝了一個(gè)名為 vue-cli-service 的命令。你可以在 npm scripts 中以 vue-cli-service、或者從終端中以 ./node_modules/.bin/vue-cli-service 訪問這個(gè)命令。

vue-cli-service serve

用法:vue-cli-service serve [options] [entry]
選項(xiàng):
--open 在服務(wù)器啟動(dòng)時(shí)打開瀏覽器
--copy 在服務(wù)器啟動(dòng)時(shí)將 URL 復(fù)制到剪切版
--mode 指定環(huán)境模式 (默認(rèn)值:development)
--host 指定 host (默認(rèn)值:0.0.0.0)
--port 指定 port (默認(rèn)值:8080)
--https 使用 https (默認(rèn)值:false)

vue-cli-service build

用法:vue-cli-service build [options] [entry|pattern]
選項(xiàng):
--mode 指定環(huán)境模式 (默認(rèn)值:production)
--dest 指定輸出目錄 (默認(rèn)值:dist)
--modern 面向現(xiàn)代瀏覽器帶自動(dòng)回退地構(gòu)建應(yīng)用
--target app | lib | wc | wc-async (默認(rèn)值:app)
--name 庫或 Web Components 模式下的名字 (默認(rèn)值:package.json 中的 "name" 字段或入口文件名)
--no-clean 在構(gòu)建項(xiàng)目之前不清除目標(biāo)目錄
--report 生成 report.html 以幫助分析包內(nèi)容
--report-json 生成 report.json 以幫助分析包內(nèi)容
--watch 監(jiān)聽文件變化

以上是兩個(gè)常用的cli指令 , 他們默認(rèn)對(duì)應(yīng)的分別是development和production模式 , 如果還想了解其他指令 , 可以訪問: https://cli.vuejs.org/zh/guide/cli-service.html#cli-%E6%9C%8D%E5%8A%A1 CLI 服務(wù)

那么接下來 , 我們就開始創(chuàng)建一個(gè)用于打包測(cè)試環(huán)境的模式;

修改package.json

添加一行命令

"test": "vue-cli-service build --mode test"

添加.env.test文件

在項(xiàng)目根路徑創(chuàng)建.env.test文件,內(nèi)容為

NODE_ENV='production' //表明這是生產(chǎn)環(huán)境(需要打包)
VUE_APP_CURRENTMODE='test' // 表明生產(chǎn)環(huán)境模式信息
VUE_APP_BASEURL='http://***.****.com:8000' // 測(cè)試服務(wù)器地址

修改項(xiàng)目中的api接口文件

在我的項(xiàng)目中,一般會(huì)創(chuàng)建一個(gè)api.js 來管理所有的接口url

因?yàn)槲覀冊(cè)诒镜亻_發(fā)環(huán)境中是通過代理來連接服務(wù)器的,所以將url寫成這

`${baseUrl}/apis/v1/login`,

在文件開頭通過環(huán)境變量改變baseUrl

let baseUrl = '';
if (process.env.NODE_ENV == 'development') {
 baseUrl = "" 
} else if (process.env.NODE_ENV == 'production') {
 baseUrl = process.env.VUE_APP_BASEURL
} else {
 baseUrl = "" 
}

當(dāng)需要為測(cè)試環(huán)境進(jìn)行打包的時(shí)候 , 我們只需要運(yùn)行下面指令進(jìn)行打包

npm run test

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue中引入第三方字體文件的方法示例

    vue中引入第三方字體文件的方法示例

    這篇文章主要介紹了vue中引入第三方字體文件的方法示例,文中講述了實(shí)現(xiàn)方法及其錯(cuò)誤的解決,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-12-12
  • vue前端通過騰訊接口獲取用戶ip的全過程

    vue前端通過騰訊接口獲取用戶ip的全過程

    今天在寫項(xiàng)目掉接口的時(shí)候有一個(gè)接口需要到了用戶的ip地址,查了半天覺得這個(gè)方法不錯(cuò),下面這篇文章主要給大家介紹了關(guān)于vue前端通過騰訊接口獲取用戶ip的相關(guān)資料,需要的朋友可以參考下
    2022-12-12
  • vue3中ace-editor的簡單使用方法實(shí)例

    vue3中ace-editor的簡單使用方法實(shí)例

    這篇文章主要給大家介紹了關(guān)于vue3中ace-editor簡單使用的相關(guān)資料,ace-editor是一種代碼編輯器,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-10-10
  • Vue使用fabric.js實(shí)現(xiàn)局部截圖與大圖預(yù)覽功能

    Vue使用fabric.js實(shí)現(xiàn)局部截圖與大圖預(yù)覽功能

    這篇文章主要為大家詳細(xì)介紹了Vue如何使用fabric.js實(shí)現(xiàn)局部截圖與el-image-viewer大圖預(yù)覽功能,文中的示例代碼講解詳細(xì),感興趣的可以了解下
    2024-02-02
  • Vue3?setup添加name的方法步驟

    Vue3?setup添加name的方法步驟

    如果你在 vue3 開發(fā)中使用了語法的話,對(duì)于組件的name屬性,需要做一番額外的處理,下面這篇文章主要給大家介紹了關(guān)于Vue3?setup添加name的相關(guān)資料,需要的朋友可以參考下
    2022-11-11
  • vue插值表達(dá)式和v-text指令的區(qū)別

    vue插值表達(dá)式和v-text指令的區(qū)別

    這篇文章主要介紹了vue插值表達(dá)式和v-text指令的區(qū)別,{{}}這種語法叫做插值表達(dá)式,在插值表達(dá)式中可以寫任何合法的js表達(dá)式,下面來看看文章是怎么介紹該內(nèi)容的吧,需要的朋友可以參考一下
    2021-11-11
  • vue實(shí)現(xiàn)多條件篩選超簡潔代碼

    vue實(shí)現(xiàn)多條件篩選超簡潔代碼

    這篇文章主要給大家介紹了關(guān)于vue實(shí)現(xiàn)多條件篩選的相關(guān)資料,隨著數(shù)據(jù)的不斷增多,我們往往需要在表格中進(jìn)行多條件的篩選,以便快速定位符合我們需求的數(shù)據(jù),需要的朋友可以參考下
    2023-09-09
  • vue中引入高德地圖并多點(diǎn)標(biāo)注的實(shí)現(xiàn)步驟

    vue中引入高德地圖并多點(diǎn)標(biāo)注的實(shí)現(xiàn)步驟

    這篇文章主要介紹了vue中引入高德地圖并多點(diǎn)標(biāo)注,實(shí)現(xiàn)步驟是通過vue的方法引入地圖,初始化地圖,設(shè)置寬和高,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-09-09
  • vue實(shí)現(xiàn)左右滑動(dòng)效果實(shí)例代碼

    vue實(shí)現(xiàn)左右滑動(dòng)效果實(shí)例代碼

    左右滾動(dòng)的效果,在日常開發(fā)中比較常見,這篇文章主要給大家介紹了關(guān)于vue實(shí)現(xiàn)左右滑動(dòng)效果的相關(guān)資料,需要的朋友可以參考下
    2021-05-05
  • vue單頁開發(fā)父子組件傳值思路詳解

    vue單頁開發(fā)父子組件傳值思路詳解

    這篇文章主要介紹了vue單頁開發(fā)父子組件傳值思路詳解,本文是小編抽空整理的思路,感興趣的朋友跟隨腳本之家小編一起學(xué)習(xí)吧
    2018-05-05

最新評(píng)論