亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

一文搞明白vue開發(fā)者vite多環(huán)境配置

 更新時間:2023年06月06日 09:21:48   作者:香菜+  
Vue是一款流行的JavaScript框架,用于開發(fā)動態(tài)單頁應(yīng)用程序,本地安裝和環(huán)境配置是學(xué)習(xí)和使用Vue的第一步,下面這篇文章主要給大家介紹了關(guān)于vue開發(fā)者vite多環(huán)境配置的相關(guān)資料,需要的朋友可以參考下

在看項目的過程中,發(fā)現(xiàn)有類似服務(wù)端多環(huán)境配置的配置,所以研究了下,在網(wǎng)上有多個方案,選了一個當(dāng)前在用的吧,另外一個沒驗證

1、原理

對于使用Vite構(gòu)建的Vue項目,可以使用Vite提供的環(huán)境變量來實現(xiàn)多環(huán)境配置。

Vite 使用 dotenv 從 環(huán)境文件目錄 中加載環(huán)境文件,默認(rèn)情況下,環(huán)境文件目錄為項目的根目錄,即把環(huán)境文件放在項目根目錄下。

環(huán)境文件命名如下:

.env                # 所有情況下都會加載
.env.local          # 所有情況下都會加載,但會被 git 忽略
.env.[mode]         # 只在指定模式下加載
.env.[mode].local   # 只在指定模式下加載,但會被 git 忽略

不同環(huán)境的變量可以定義在 .env.[mode] 文件中,如 .env.dev、.env.prod 等,如果 .env 文件和 .env.[mode] 中有相同的 key,后者定義的值會覆蓋前者。

這里咱們以三個環(huán)境為例編寫 demo,分別是:

  • 開發(fā)環(huán)境,mode 為 dev,文件名為 .env.dev
  • 測試環(huán)境,mode 為 uat,文件名為 .env.uat
  • 生產(chǎn)環(huán)境,mode 為 prod,文件名為 .env.prod

2、創(chuàng)建配置文件 

使用 .env 文件來設(shè)置特定環(huán)境的變量。Vite 會自動加載 .env 文件,而且支持使用不同的 .env 文件來為不同的環(huán)境提供變量。

在項目根目錄下創(chuàng)建.env.dev、.env.test.env.prod等環(huán)境變量文件,并在其中定義各個環(huán)境的變量。例如:

NODE_ENV="development"
VITE_BASE_API="http://172.26.1.152:80"
VITE_BASE_WS="ws://172.26.1.152:18083"

注意,變量名必須以VITE_開頭,這是Vite默認(rèn)的前綴。

3、使用多環(huán)境配置

package.json中配置啟動腳本,使用配置

  "scripts": {
    "dev": "vite --mode dev",
    "test": "vite --mode test",
    "prod": "vite --mode prod",
    "build": "vue-tsc && vite build",
    "build:dev": "vue-tsc --noEmit && vite build --mode dev",
    "build:prod": "vue-tsc --noEmit && vite build --mode prod",
    "preview": "vite preview"
  },

4、使用環(huán)境變量

在Vue組件中使用環(huán)境變量:

<template>
  <div>
    <p>{{ apiURL }}</p>
  </div>
</template>
 
<script>
export default {
  data() {
    return {
      apiURL: import.meta.env.VITE_BASE_API
    }
  }
}
</script>

在Vue組件中可以通過import.meta.env.VITE_API_URL來訪問環(huán)境變量。

5、關(guān)于編輯器提示

可以添加 vite-env.d.ts解決。如果不存在這個文件,在 src 目錄下創(chuàng)建文件 vite-env.d.ts,我的項目下有,不記得是不是自己手動創(chuàng)建了

/// <reference types="vite/client" />
?
interface ImportMetaEnv {
  readonly VITE_BASE_API: string;
  readonly VITE_BASE_WS: string;
}?

6、最后驗證下

main.ts 打印下環(huán)境變量

客戶端訪問,打開控制臺可以看到環(huán)境變量,試著切換下看看生效了嗎

7、process.env和import.meta.env

process.env是Node.js中的全局變量,用于訪問進程中的環(huán)境變量。在前端開發(fā)中,我們通常使用Webpack等構(gòu)建工具來打包應(yīng)用程序,因此需要在構(gòu)建過程中設(shè)置環(huán)境變量。在Webpack中,可以使用DefinePlugin插件將環(huán)境變量注入到應(yīng)用程序中,然后在代碼中通過process.env來訪問這些變量。

例如,在Webpack中設(shè)置一個名為API_URL的環(huán)境變量,可以在代碼中通過process.env.API_URL來訪問它:

// webpack.config.js
module.exports = {
  plugins: [
    new webpack.DefinePlugin({
      'process.env.API_URL': JSON.stringify('https://api.example.com')
    })
  ]
}
 
// app.js
console.log(process.env.API_URL) // 'https://api.example.com'

import.meta.env是在ES模塊中定義的全局變量,用于訪問Vite構(gòu)建的應(yīng)用程序中的環(huán)境變量。在Vite中,可以在.env文件中定義環(huán)境變量,然后在Vue組件和JavaScript模塊中通過import.meta.env來訪問這些變量。

需要注意的是,process.envimport.meta.env的作用域不同,前者作用于整個Node.js進程,后者只作用于當(dāng)前的JavaScript模塊或Vue組件。因此,它們的用法和使用場景也有所不同。

總結(jié)

到此這篇關(guān)于vue開發(fā)者vite多環(huán)境配置的文章就介紹到這了,更多相關(guān)vue vite多環(huán)境配置內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue項目實現(xiàn)會議預(yù)約功能(包含某天的某個時間段和某月的某幾天)

    vue項目實現(xiàn)會議預(yù)約功能(包含某天的某個時間段和某月的某幾天)

    這篇文章主要介紹了vue項目實現(xiàn)會議預(yù)約功能(包含某天的某個時間段和某月的某幾天),本文結(jié)合實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-02-02
  • 詳解vue 模版組件的三種用法

    詳解vue 模版組件的三種用法

    本篇文章主要介紹了詳解vue 模版組件的三種用法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • Element-Ui組件 NavMenu 導(dǎo)航菜單的具體使用

    Element-Ui組件 NavMenu 導(dǎo)航菜單的具體使用

    這篇文章主要介紹了Element-Ui組件 NavMenu 導(dǎo)航菜單的具體使用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • Vue子父組件之間傳值的三種方法示例

    Vue子父組件之間傳值的三種方法示例

    Vue的組件化給前端開發(fā)帶來極大的便利,下面這篇文章主要給大家介紹了關(guān)于Vue子父組件之間傳值的三種方法,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-02-02
  • vue項目拍照或上傳圖片并實現(xiàn)轉(zhuǎn)化為base64格式

    vue項目拍照或上傳圖片并實現(xiàn)轉(zhuǎn)化為base64格式

    這篇文章主要介紹了vue項目拍照或上傳圖片并實現(xiàn)轉(zhuǎn)化為base64格式方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • vue 通過 mqtt 實現(xiàn)實時接收消息的操作方法

    vue 通過 mqtt 實現(xiàn)實時接收消息的操作方法

    ?MQTT是一種基于發(fā)布/訂閱模式的輕量級消息協(xié)議,適用于硬件性能有限的遠程設(shè)備和網(wǎng)絡(luò)狀況不佳的環(huán)境,這篇文章主要介紹了vue 通過 mqtt 實現(xiàn)實時接收消息,需要的朋友可以參考下
    2024-12-12
  • vue3+Typescript實現(xiàn)路由標(biāo)簽頁和面包屑功能

    vue3+Typescript實現(xiàn)路由標(biāo)簽頁和面包屑功能

    在使用 Vue.js 開發(fā)后臺管理系統(tǒng)時,經(jīng)常會遇到需要使用路由標(biāo)簽頁的場景,這篇文章主要介紹了vue3+Typescript實現(xiàn)路由標(biāo)簽頁和面包屑,需要的朋友可以參考下
    2023-05-05
  • vue3.0 CLI - 2.5 - 了解組件的三維

    vue3.0 CLI - 2.5 - 了解組件的三維

    通過本文帶領(lǐng)大家去學(xué)習(xí)vue3.0 CLI - 2.5 - 了解組件的三維的相關(guān)知識,感興趣的朋友跟隨腳本之家小編一起學(xué)習(xí)吧
    2018-09-09
  • vue實現(xiàn)圖片懶加載的方法分析

    vue實現(xiàn)圖片懶加載的方法分析

    這篇文章主要介紹了vue實現(xiàn)圖片懶加載的方法,結(jié)合實例形式分析了vue.js圖片懶加載插件安裝、使用方法與相關(guān)操作注意事項,需要的朋友可以參考下
    2020-02-02
  • vue中控制mock在開發(fā)環(huán)境使用,在生產(chǎn)環(huán)境禁用方式

    vue中控制mock在開發(fā)環(huán)境使用,在生產(chǎn)環(huán)境禁用方式

    這篇文章主要介紹了vue中控制mock在開發(fā)環(huán)境使用,在生產(chǎn)環(huán)境禁用方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04

最新評論