Vue3+Vite +dotenvx读取.env文件参数

第一步:安装安装 dotenvx

第二步:查看版本 dotenvx --version

第三步:执行 dotenvx run -f .env.development -- npm run dev

第四步:读取import.meta.env.VITE_API_BASE_URL

会报错

解决方案:

安装浏览器兼容包:

项目根目录执行 npm install tty-browserify process 命令

然后修改Vite配置:

vite.config.js

import { defineConfig } from 'vite'

export default defineConfig({

resolve: {

alias: {

tty: 'tty-browserify',

process: 'process/browser'

}

},

define: {

'process.env.NODE_DEBUG': JSON.stringify(false)

}

})

这样就好了 然后读取就正常了

切换开发环境和生产环境参数

开发环境 dotenvx run -f .env.development -- npm run dev

生产环境 dotenvx run -f .env.production -- npm run dev

如何实现自由切换呢?

通过在 package.jsonscripts字段中预先定义好各环境的命令。

  1. 配置 package.json

    将你的命令固化到 scripts中,例如:

    复制代码

    json

    json

    复制

    复制代码
    {
      "scripts": {
        "dev": "dotenvx run -f .env.development -- npm run dev",
        "dev:prod": "dotenvx run -f .env.production -- npm run dev",
        "build": "vite build",
        "build:prod": "dotenvx run -f .env.production -- vite build",
        "preview": "vite preview"
      }
    }
  2. 使用命令

    • 开发环境 :执行 npm run dev

    • 模拟生产环境运行 :执行 npm run dev:prod

    • 构建生产包 :执行 npm run build:prod

    • 如果上边报错就用下边这种方式

{

"scripts": {

"dev": "vite --mode development",

"build:dev": "vite build --mode development",

"build:prod": "vite build --mode production",

"preview": "vite preview"

}

}

相关推荐
Curvatureflight1 天前
前端国际化 i18n 落地实践:语言包、动态文案和格式化问题怎么处理?
前端·c++·vue
优雅格子衫1 天前
uniapp 拍照相册选取后超级好用的裁剪组件,增加水印完全自定义
开发语言·前端·javascript·uni-app·vue
路光.2 天前
uniapp中解决webview在app中调用,有过渡空白问题,增加过渡动效
uni-app·vue·app·uniapp
暗冰ཏོ2 天前
《2026 Vue2 + Vue3 完整学习指南:基础语法、路由缓存、登录拦截、项目实战与面试题》
前端·vue.js·vue·vue3·vue2
七仔啊2 天前
cad文件在线查看
vue
相忘于江湖4265433 天前
vs code 代码保存自动格式化
前端·vue
study-Java4 天前
校园失物招领平台
java·spring boot·vue·intellij-idea·visual studio code
MaCa .BaKa5 天前
53-智慧工地人员考勤与工时管理系统
java·spring boot·mysql·tomcat·vue·maven
华玥作者6 天前
从“碎片化”到“资产化”:Vue3 + UniApp 组件库的进化论
ui·uni-app·vue·组件库
薛定谔的猫喵喵6 天前
从零到一:Spring Boot + Vue 项目前后端运行完整指南
vue.js·spring boot·后端·pycharm·vue