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。

### Vite Vue3 多页面应用配置教程 在现代前端开发中,多页面应用(MPA, Multi-Page Application)的需求仍然存在,尤其是在一些特定场景下,比如企业级后台管理系统或者浏览器插件开发。以下是关于如何在基于 ViteVue3 的项目中实现多页面配置的具体方法。 #### 1. 创建基础目录结构 为了支持多个页面,首先需要调整项目的目录结构以适应多入口需求。通常的做法是在 `src` 目录下创建一个子文件夹来存储不同页面的资源文件。例如: ```plaintext /src/ /pages/ /home/ main.js // Home 页面的入口文件 App.vue // Home 页面的根组件 /about/ main.js // About 页面的入口文件 App.vue // About 页面的根组件 ``` 这种分层设计有助于清晰管理各个页面的逻辑和样式[^2]。 --- #### 2. 修改 Vite 配置文件 通过自定义 `vite.config.ts` 来设置多页面的支持能力。具体来说,可以通过指定多个入口并生成对应的 HTML 文件完成此操作。以下是一个完整的配置示例: ```javascript import { defineConfig } from &#39;vite&#39;; import vue from &#39;@vitejs/plugin-vue&#39;; export default defineConfig({ plugins: [ vue(), ], build: { rollupOptions: { input: { home: &#39;./src/pages/home/main.js&#39;, // 定义首页入口 about: &#39;./src/pages/about/main.js&#39; // 定义关于页入口 } } }, }); ``` 上述代码片段展示了如何利用 Rollup 的 `input` 属性为不同的页面分配独立的入口脚本。 --- #### 3. 动态生成 HTML 文件 对于每一个入口都需要有一个关联的 HTML 文件作为模板渲染目标。可以借助插件如 `@vitejs/plugin-html` 或者手动编写静态 HTML 模板。如果采用动态方式,则可以在 `vite.config.ts` 中进一步扩展如下所示: ```typescript import { defineConfig } from &#39;vite&#39;; import vue from &#39;@vitejs/plugin-vue&#39;; import path from &#39;path&#39;; // 自动化处理HTML文件路径映射函数 function generateHtmlPlugins(pagesDir) { const pages = [&#39;home&#39;, &#39;about&#39;]; // 假设只有两个页面 return pages.map(page => ({ name: `${page}-html`, transformIndexHtml(html) { return html.replace(&#39;__PAGE_NAME__&#39;, page); }, writeBundle() { this.emitFile({ type: &#39;asset&#39;, fileName: `${page}.html`, source: ` <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <link rel="icon" href="/favicon.ico"> <title>${page.charAt(0).toUpperCase() + page.slice(1)}</title> <!-- 自动生成标题 --> </head> <body> <div id="app"></div> <script type="module" src="${path.resolve(__dirname, `./src/pages/${page}/main.js`)}}"></script> </body> </html>` }); } })); } export default defineConfig({ plugins: [...generateHtmlPlugins(&#39;src/pages&#39;), vue()], }); ``` 这段代码实现了自动化生成每个页面所需的 HTML 文件,并确保它们能够正确加载各自的 JavaScript 资源。 --- #### 4. 设置环境变量 `.env` 文件允许开发者轻松切换不同环境下使用的 API 地址或其他全局参数。例如,在 `.env.development` 中可设定本地调试服务器地址;而在生产环境中则指向实际部署的服务端接口位置[^1]: ```plaintext # .env.development VITE_APP_API_BASE_URL=http://localhost:3000 # .env.production VITE_APP_API_BASE_URL=https://api.example.com ``` 这些变量可以直接通过 `import.meta.env.VITE_APP_API_BASE_URL` 访问使用。 --- #### 5. 构建与运行 执行标准命令即可启动服务或打包项目: ```bash pnpm run dev # 开发模式 pnpm run build # 生产模式 ``` 完成后会在 dist 文件夹里看到对应于各页面的输出结果,包括 CSS、JS 及其相应的 HTML 文档。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

吕彬-前端

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

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

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

打赏作者

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

抵扣说明:

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

余额充值