解决 Vite 项目中 import.meta.env 变量为 undefined 的问题

解决 Vite 项目中 import.meta.env 变量为 undefined 的问题

问题描述

在使用 Vite + Vue 3 的项目开发过程中,我遇到了一个奇怪的问题:尽管在 .env.development 文件中正确配置了环境变量,但在代码中通过 import.meta.env.VITE_API_BASE_URL 访问时却返回 undefined

javascript 复制代码
onMounted(() => {
  console.log(import.meta.env.VITE_API_BASE_URL); // 输出: undefined
})

环境配置

项目中的 .env.development 文件内容如下:

env 复制代码
VITE_API_BASE_URL=http://172.20.10.10:8890/api
VITE_ENV=development

问题排查

1. 检查环境变量前缀

Vite 默认只暴露以 VITE_ 为前缀的环境变量到客户端代码中。确认我们的变量名 VITE_API_BASE_URL 符合这个要求。

2. 检查 Vite 配置

查看 vite.config.ts 文件,确认没有自定义的 envPrefix 配置:

typescript 复制代码
export default defineConfig({
  // ... 其他配置
  // 没有设置 envPrefix,使用默认的 VITE_
})

3. 检查文件编码问题(关键发现)

通过查看文件内容,发现 .env.development 文件存在编码问题:

复制代码
# 文件开头包含 UTF-16 BOM 标记
��# . e n v . d e v e l o p m e n t 

文件被保存为 UTF-16 编码,包含了 BOM(Byte Order Mark),这导致 Vite 无法正确解析环境变量。

解决方案

方法一:重新创建环境文件

  1. 删除现有的 .env.development 文件
  2. 使用文本编辑器(如 VS Code、Notepad++ 等)重新创建文件
  3. 确保文件保存为 UTF-8 编码(无 BOM)
  4. 重新写入环境变量配置:
env 复制代码
VITE_API_BASE_URL=http://172.20.10.10:8890/api
VITE_ENV=development

方法二:使用命令行重新写入

bash 复制代码
# 使用 echo 命令重新创建文件(确保 UTF-8 编码)
echo "VITE_API_BASE_URL=http://172.20.10.10:8890/api
VITE_ENV=development" > .env.development

验证修复

修复后,重启开发服务器:

bash 复制代码
npm run dev

在代码中验证环境变量:

javascript 复制代码
onMounted(() => {
  console.log(import.meta.env.VITE_API_BASE_URL); // 现在应该输出: http://172.20.10.10:8890/api
})

预防措施

  1. 统一编辑器编码设置:确保所有开发工具都使用 UTF-8 编码保存文件
  2. 检查文件编码:在编辑器中查看文件编码状态,确保是 UTF-8(无 BOM)
  3. 版本控制 :在 .gitattributes 中设置文本文件的编码:
gitattributes 复制代码
*.env text working-tree-encoding=UTF-8

总结

Vite 环境变量为 undefined 的问题通常与以下因素相关:

  • 环境变量命名不符合 VITE_ 前缀要求
  • 文件编码问题(如 UTF-16 BOM)
  • Vite 配置中自定义了 envPrefix
  • 开发服务器未重启

通过系统性地排查这些因素,特别是注意文件编码问题,可以有效解决此类问题。

参考文档

相关推荐
ZC跨境爬虫16 小时前
跟着 MDN 学 HTML day_9:(信件语义标记)
前端·css·笔记·ui·html
前端老石人16 小时前
HTML 字符引用完全指南
开发语言·前端·html
matlab_xiaowang16 小时前
Redux 入门:JavaScript 可预测状态管理库
开发语言·javascript·其他·ecmascript
幼儿园技术家16 小时前
前端如何设计权限系统(RBAC / ABAC)?
前端
前端摸鱼匠18 小时前
Vue 3 的v-bind合并行为:讲解v-bind与普通属性合并的规则
前端·javascript·vue.js·前端框架·ecmascript
REDcker18 小时前
浏览器端Web程序性能分析与优化实战 DevTools指标与工程清单
开发语言·前端·javascript·vue·ecmascript·php·js
donecoding20 小时前
一个 sudo 引发的血案:npm 全局包权限错乱彻底修复
前端·node.js·前端工程化
风骏时光牛马20 小时前
Raku正则匹配与数据批量处理实操案例
前端
nbwenren20 小时前
2026实测:Gemini 3 镜像站视觉能力实践——拍照原型图,一键生成 HTML+CSS 代码
前端·css·html
Lee川20 小时前
Prisma 实战指南:像搭积木一样设计古诗词数据库
前端·数据库·后端