Vite 与 Webpack 开发/打包时环境变量对比

一句话总区别

  1. Webpack (vue-cli 也是)

    环境变量必须以 VUE_APP_ 开头

    访问方式:process.env.XXX

  2. Vite

    环境变量必须以 VITE_ 开头

    访问方式:import.meta.env.XXX

这是最本质、最底层的两个区别。


完整对比表(直接收藏)

对比项 Webpack / vue-cli Vite
环境变量前缀 VUE_APP_ VITE_
客户端访问方式 process.env.VUE_APP_XXX import.meta.env.VITE_XXX
内置默认变量 process.env.NODE_ENV import.meta.env.MODE / PROD / DEV
环境文件 .env, .env.development, .env.production 一样:.env, .env.development, .env.production
环境文件加载时机 启动时加载 启动时加载
能否在 vite.config.ts / vue.config.js 中使用 ✅ 可以直接用 process.env 不可以 ,必须用 loadEnv 手动加载
服务端/配置文件使用 天然支持 需手动加载
注入原理 打包时字符串替换 利用 ES 模块 import.meta 对象
是否支持 CommonJS 否(ESM 规范)
热更新感知 修改 .env 需重启服务 修改 .env 需重启服务

逐点详细讲解(最关键)

1. 变量前缀不同

  • Webpack :必须 VUE_APP_XXX
  • Vite :必须 VITE_XXX

不按规则写 → 客户端获取不到!


2. 访问方式完全不同

Webpack

js 复制代码
console.log(process.env.VUE_APP_API_URL)

Vite

js 复制代码
console.log(import.meta.env.VITE_API_URL)

不能混用!

  • Vite 里写 process.env → 直接报错
  • Webpack 里写 import.meta.env → 报错

3. 内置环境变量不同

Webpack 自带

复制代码
process.env.NODE_ENV
process.env.BASE_URL

Vite 自带

复制代码
import.meta.env.MODE      环境模式
import.meta.env.PROD     是否生产
import.meta.env.DEV      是否开发
import.meta.env.BASE_URL 基础路径

4. 配置文件中使用环境变量(最大坑点)

Webpack

直接用,天然支持:

js 复制代码
// vue.config.js
console.log(process.env.VUE_APP_API_URL)

Vite

不能直接用!

必须用 loadEnv 手动加载:

js 复制代码
// vite.config.ts
import { defineConfig, loadEnv } from 'vite'

export default defineConfig(({ mode }) => {
  const env = loadEnv(mode, process.cwd())
  console.log(env.VITE_API_URL) // 必须这样拿

  return { plugins: [] }
})

5. 注入原理不同

  • Webpack

    process.env.XXX 编译时替换成字符串

  • Vite

    利用 ESM 规范的 import.meta 注入环境变量

    是标准 ES 语法


6. 环境文件格式

两者完全一样

复制代码
.env                所有环境都加载
.env.development     开发环境
.env.production      生产环境

最容易踩的 4 个坑

  1. Vite 不能用 process.env → 报错 is not defined
  2. 变量不加 VITE_ / VUE_APP_ → 客户端拿不到
  3. vite.config.ts 里直接写 import.meta.env → 拿不到,必须 loadEnv
  4. 修改 .env 不重启服务 → 不生效

最终极简记忆(10 秒记住)

  • Webpack = process.env + VUE_APP_
  • Vite = import.meta.env + VITE_
  • 配置文件里:webpack 直接用,vite 要 loadEnv
相关推荐
donecoding26 分钟前
一个 sudo 引发的血案:npm 全局包权限错乱彻底修复
前端·node.js·前端工程化
风骏时光牛马31 分钟前
Raku正则匹配与数据批量处理实操案例
前端
nbwenren34 分钟前
2026实测:Gemini 3 镜像站视觉能力实践——拍照原型图,一键生成 HTML+CSS 代码
前端·css·html
Lee川36 分钟前
Prisma 实战指南:像搭积木一样设计古诗词数据库
前端·数据库·后端
jinanwuhuaguo1 小时前
(第二十九篇)OpenClaw 实时与具身的跃迁——从异步孤岛到数字世界的“原住民”
前端·网络·人工智能·重构·openclaw
广州华水科技1 小时前
深度测评2026年单北斗GNSS位移监测系统推荐,与高口碑变形监测设备一同引领行业新风尚
前端
Alice-YUE2 小时前
【js高频八股】防抖与节流
开发语言·前端·javascript·笔记·学习·ecmascript
是上好佳佳佳呀3 小时前
【前端(十一)】JavaScript 语法基础笔记(多语言对比)
前端·javascript·笔记
CDN3604 小时前
排查实录:网站偶发502/504错误?360CDN回源超时配置与日志分析技巧
前端·数据库