Vite+Vue 3 环境变量配置

在开发 Web 应用时,我们常常需要根据不同的环境(如开发、测试、生产)进行不同的配置。

Vite 提供了灵活的环境变量配置机制在一个特殊的 import.meta.env 对象上暴露环境变量,这些变量在构建时会被静态地替换掉。让我们可以轻松管理这些差异。

env环境变量的作用

  • 在不同的环境下,请求不同的环境的服务;
  • 在不同环境下,加载不同的插件,或者代码判断某些场景。
  • 打包时的不同环境的配置。

我们可以使用多个环境变量文件来管理不同环境下的配置。这些文件通常放在项目根目录下,文件名格式为 .env.env.development.env.production 等。

基础环境变量文件

创建 .env 文件,用于存储所有环境通用的变量:

# .env
VUE_APP_TITLE = Vue App

本地环境变量文件

创建 .env.local 文件,用于存储所有环境通用的变量:

# .env.local
VUE_APP_API_URL= "http:127.0.0.1:3000/api"

开发环境变量文件

创建 .env.development 文件,用于存储开发环境下的变量:

# .env.development
VUE_APP_API_URL= http://xxx:3000/api

生产环境变量文件

创建 .env.production 文件,用于存储生产环境下的变量:

# .env.production
VUE_APP_API_URL= https://xxx.com

package.json文件配置

示例代码

{
  "name": "vite-project",
  ...,//其他配置
  "scripts": {
    "dev": "vite -- mode development",
    "loc": "vite -- mode localhost",
    "build:dev": "vite build -- mode development",
    "build:pro": "vite build -- mode production",
    "build": "vite-tsc && vite build",
    "preview": "vite preview"
  }
}
  • npm run dev,就是运行对应env.development环境,取其文件的内容使用。
  • npm run loc ,对应env.localhost文件。
  • npm run pro 一般不会这样。
  • npm build:dev 打包,打对应env.development环境包。
  • npm build:pro 打包,打对应env.production环境的包。
  • npm run preview 这是vite的黑科技,它可以启动本地服务,去运行或者叫预览你打的包dist文件。先npm run build:dev,再npm run preview

在代码中使用环境变量

在 Vue 3 项目中,我们可以通过 import.meta.env 访问环境变量。

示例代码

<template>
  <div>
    <h1>{{ title }}</h1>
    <p>API URL: {{ apiUrl }}</p>
  </div>
</template>

<script setup>
const title = import.meta.env.VUE_APP_TITLE;
const apiUrl = import.meta.env.VUE_APP_API_URL;
</script>

在构建过程中使用环境变量

除了在代码中使用环境变量,我们还可以在构建过程中根据不同的环境变量进行特定的操作。例如,可以根据环境变量配置不同的插件或优化选项。

Vite 配置

在使用 Vite 构建工具时,我们可以在 vite.config.ts 文件中访问环境变量:

import { defineConfig } from 'vite';
import vue from '@vitejs/plugin-vue';

export default defineConfig({
  plugins: [vue()],
  define: {
    'process.env': {
      VUE_APP_TITLE: JSON.stringify(process.env.VUE_APP_TITLE),
      VUE_APP_API_URL: JSON.stringify(process.env.VUE_APP_API_URL),
    },
  },
});

部署时的环境变量配置 

在实际部署中,我们通常会使用 CI/CD 工具来自动化部署流程。在部署过程中,可以根据不同的环境注入相应的环境变量。

示例代码

使用 GitHub Actions 配置环境变量,在 .github/workflows/deploy.yml 文件中,我们可以配置环境变量:

name: Deploy

on:
  push:
    branches:
      - main

jobs:
  build-and-deploy:
    runs-on: ubuntu-latest
    steps:
      - name: Checkout code
        uses: actions/checkout@v2

      - name: Setup Node.js
        uses: actions/setup-node@v2
        with:
          node-version: '14'

      - name: Install dependencies
        run: npm install

      - name: Build project
        run: npm run build
        env:
          VUE_APP_API_URL: ${{ secrets.PRODUCTION_API_URL }}

      - name: Deploy to server
        run: echo "Deploying..."

在 GitHub 仓库中设置 PRODUCTION_API_URL 秘密变量,以确保部署过程中使用正确的 API URL。

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
配置Vue3 + Vite + TypeScript环境中,可以按照以下步骤进行操作: 1. 创建项目:根据中的引用,您可以创建一个新的项目。 2. 路由配置修改:根据中的引用,您可以修改基础路由和路由守卫配置。 3. Pinia配置修改:根据中的引用,您可以修改Pinia配置。 4. 生产与开发环境配置:根据和中的引用,您可以创建.env.production和.env.development文件,并在其中配置相应的变量。 5. 其余小配置:根据中的引用,您可以进行其他小配置的修改,比如自启与Network的配置、自动引入组件和Vue方法的插件配置等。 具体操作步骤如下: 1. 在根目录下创建.env.production和.env.development文件,并在其中配置变量以VITE_开头,后面接变量名。例如,可以配置VITE_ENV来指定环境,VITE_APP_BASE_API来指定基地址等。 2. 根据需要,修改项目的路由配置,包括基础路由和路由守卫配置。 3. 根据需要,修改Pinia的配置。 4. 根据需要,进行其他小配置的修改,比如自启与Network的配置、自动引入组件和Vue方法的插件配置等。 请注意,这只是一个大致的操作指南,具体的配置过程可能会因项目需求而有所不同。建议您参考相关文档和教程,以确保正确配置您的Vue3 + Vite + TypeScript项目的环境。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [关于vue3+vite+ts项目搭建配置](https://blog.csdn.net/qq_58061710/article/details/129497444)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [Vite + Vue3 + ts 注册登录页面书写 搭配Nodejs + Express + postgresql接口](https://download.csdn.net/download/qq_42425561/85103234)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

吕彬-前端

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值