vue多环境变量 .env配置

文章讲述了在Vue项目中如何管理和使用.env文件来设置环境变量,特别是.NODE_ENV,BASE_URL和VUE_APP_开头的变量会被静态嵌入到客户端代码。.env.[mode]文件用于特定模式,如production,具有更高优先级。通过vue-cli-service工具,可以进行不同模式的构建,如预发布(pre)环境的配置和构建。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

.env                # 在所有的环境中被载入
.env.[mode]         # 只在指定的模式中被载入

只有 NODE_ENV,BASE_URL 和以 VUE_APP_ 开头的变量将通过 webpack.DefinePlugin 静态地嵌入到客户端侧的代码中

优先级

为一个特定模式准备的环境文件 (例如 .env.production) 将会比一般的环境文件 (例如 .env) 拥有更高的优先级。

使用

1.创建 .env.pre
在这里插入图片描述
2. 配置.env.pre环境变量

VUE_APP_STATIC_PATH = /

3.在package.json中添加运行命令

  "scripts": {
    "dev": "vue-cli-service serve",
    "serve": "vue-cli-service serve",
    "build": "vue-cli-service build",
    "pre": "vue-cli-service build --mode pre", 
    "lint": "vue-cli-service lint",
    "eslint": "eslint ./src/**/*.vue --fix"
  },
### 配置 Vue 3 中的 `process.env` 环境变量 在 Vue 3 项目中,配置 `process.env` 环境变量主要依赖于 `.env` 文件以及 Node.js 的顶层对象 `process.env` 属性。这允许开发者根据不同环境(如开发、测试、生产)来设置不同的配置项。 #### 创建不同环境的配置文件 对于不同环境下的配置管理,通常会创建多个`.env`文件: - **.env**: 基础配置,默认情况下适用于所有环境。 - **.env.development** 或者 **.env.dev**: 开发环境下使用的特定配置。 - **.env.production** 或者 **.env.prod**: 生产环境中应用的独特设定[^1]。 这些文件应当放置在项目的根目录下,并遵循一定的命名约定以便被识别加载。 #### 设置环境变量前缀 VUE_APP_ 值得注意的是,在 Vue CLI 构建的应用里,只有定义了以 `VUE_APP_` 开头的自定义环境变量才会暴露给客户端代码访问。这是因为直接暴露出所有的环境变量可能存在安全隐患。因此,如果希望某些变量能够在前端 JavaScript 中读取,则需按照此规则声明它们[^2]。 例如,在 `.env.development` 文件内可以这样写: ```bash # .env.development VUE_APP_API_URL=http://localhost:8080/api/v1/ NODE_ENV=development ``` 而在 `.env.production` 文件中则可能是这样的配置: ```bash # .env.production VUE_APP_API_URL=https://api.example.com/v1/ NODE_ENV=production ``` #### 使用过程中的注意事项 一旦设置了上述环境变量并保存好对应的`.env.*`文件之后,只需要正常执行构建工具链所提供的脚本即可完成相应模式下的编译工作。比如启动本地服务器(`npm run serve`)或是打包发布版本(`npm run build`)的时候,CLI 工具会自动依据当前的工作流选择合适的环境配置并将之注入到应用程序之中[^3]。 此外,需要注意的是虽然可以通过这种方式轻松地管理和切换多套环境参数,但在实际操作过程中还是应该谨慎对待敏感数据的安全保护措施,避免不必要的风险。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值