Vue 项目中,.env文件怎么用?

ops/2025/3/11 7:11:33/

在 Vue 项目中,.env 文件用于存储环境变量,不同的环境(如开发环境、测试环境、生产环境)可以使用不同的 .env 文件来管理对应的配置信息。以下是关于 Vue 项目中 .env 文件的详细使用方法:

1. 项目创建

确保你已经使用 Vue CLI 创建了一个 Vue 项目。如果还没有创建,可以使用以下命令创建一个新的 Vue 项目:

vue create my-vue-project
cd my-vue-project

2. .env 文件的命名规则

Vue CLI 支持多种 .env 文件命名,以适应不同的环境需求:

  • .env:所有环境都会加载的通用配置。
  • .env.development:开发环境(npm run serve)加载的配置。
  • .env.production:生产环境(npm run build)加载的配置。
  • .env.test:测试环境加载的配置。

3. 定义环境变量

在相应的 .env 文件中,按照 VUE_APP_ 前缀的格式定义环境变量,例如:

  • .env.development
VUE_APP_API_BASE_URL = http://localhost:3000/api
VUE_APP_DEBUG = true
  • .env.production
VUE_APP_API_BASE_URL = https://example.com/api
VUE_APP_DEBUG = false

注意:只有以 VUE_APP_ 开头的变量才会被 Vue CLI 注入到项目中。

4. 在项目中使用环境变量

在 Vue 项目中,可以通过 process.env 对象来访问定义的环境变量。

  • 在 Vue 组件中使用
<template><div><p>API Base URL: {{ apiBaseUrl }}</p><p>Debug Mode: {{ debugMode }}</p></div>
</template><script>
export default {data() {return {apiBaseUrl: process.env.VUE_APP_API_BASE_URL,debugMode: process.env.VUE_APP_DEBUG};}
};
</script>
  • 在 JavaScript 文件中使用
javascript">// src/services/api.js
const apiBaseUrl = process.env.VUE_APP_API_BASE_URL;export function fetchData() {return fetch(`${apiBaseUrl}/data`).then(response => response.json());
}

5. 加载不同环境的配置

根据启动命令的不同,Vue CLI 会自动加载相应的 .env 文件:

  • 开发环境:运行 npm run serve 时,会加载 .env.env.development 文件,.env.development 文件中的配置会覆盖 .env 中同名的配置。
  • 生产环境:运行 npm run build 时,会加载 .env.env.production 文件,.env.production 文件中的配置会覆盖 .env 中同名的配置。

6. 自定义环境

除了默认的开发和生产环境,你还可以自定义环境。例如,创建一个 .env.staging 文件用于预发布环境:

VUE_APP_API_BASE_URL = https://staging.example.com/api
VUE_APP_DEBUG = false

然后,在 package.json 中添加自定义脚本:

{"scripts": {"serve": "vue-cli-service serve","build": "vue-cli-service build","build:staging": "vue-cli-service build --mode staging"}
}

运行 npm run build:staging 时,会加载 .env.env.staging 文件。

7. 注意事项

  • 安全性:不要在 .env 文件中存储敏感信息(如数据库密码、API 密钥等),如果需要存储敏感信息,可以考虑使用环境变量注入或加密存储。
  • 重启服务:修改 .env 文件后,需要重新启动开发服务器或重新构建项目,新的环境变量才能生效。

http://www.ppmy.cn/ops/164860.html

相关文章

linux wifi driver深度实践之内核编译加载

基础 硬件基础&#xff1a;随处可以买到的TP-WN722N V1网卡软件基础&#xff1a;linux-source-5.3.0 内核源码源码路径&#xff1a;drivers/net/wireless/ath/ath9k/常见wifi接口协议&#xff1a;包括PCIe、USB、SDIO等。 安装内核源码包 Ubuntu 提供了内核源码包&#xff0…

SpringCloud——环境搭建

一、从Boot和Cloud版本选型开始说起 &#xff08;1&#xff09;无伤速通版 &#xff08;2&#xff09;详细推演版 1.2.1SpringCloud 分为上下两场 上篇SpringCloud下篇SpringCloud Alibaba上下篇没有严格的顺序要求&#xff0c;各自独立&#xff0c;截然不同 1.2.2SpringBo…

网络DNS怎么更改?

访问速度慢或某些网站无法打开?改变网络DNS设置可能会帮助解决这些问题。本文将详细介绍如何更改网络DNS&#xff0c;包括更改的原因、具体步骤。 一、为什么要更改DNS? 更改DNS的原因有很多&#xff0c;以下是一些主要的考虑因素&#xff1a;某些公共DNS服务器的响应速度比…

STM32之I2C硬件外设

注意&#xff1a;硬件I2C的引脚是固定的 SDA和SCL都是复用到外部引脚。 SDA发送时数据寄存器的数据在数据移位寄存器空闲的状态下进入数据移位寄存器&#xff0c;此时会置状态寄存器的TXE为1&#xff0c;表示发送寄存器为空&#xff0c;然后往数据控制寄存器中一位一位的移送数…

Java进阶:Zookeeper相关笔记

概要总结&#xff1a; ●Zookeeper是一个开源的分布式协调服务&#xff0c;需要下载并部署在服务器上(使用cmd启动&#xff0c;windows与linux都可用)。 ●zookeeper一般用来实现诸如数据订阅/发布、负载均衡、命名服务、集群管理、分布式锁和分布式队列等功能。 ●有多台服…

蓝桥杯算法——铠甲合体

问题描述 暗影大帝又开始搞事情了&#xff01;这次他派出了 MM 个战斗力爆表的暗影护法&#xff0c;准备一举摧毁 ERP 研究院&#xff01;MM 个暗影护法的战斗力可分别用 B1,⋯,BMB1​,⋯,BM​ 表示。 ERP 研究院紧急召唤了 NN 位铠甲勇士前来迎战&#xff01;每位铠甲勇士都…

BGP实验(一)IBGP全互联配置

一、拓扑图 二、实验思路 根据BGP的路由优先原则&#xff0c;首先要保证路由可达。但是IBGP间存在水平分割机制&#xff0c;因此实验可使用IBGP全互联&#xff0c;反射器或联盟来实现IBGP间路由可达&#xff0c;本实验使用全互联全互联缺点&#xff1a;将BGP路由引入到IGP&…

react拖曳组件react-dnd的简单封装使用

分享原因 由于项目中需要使用拖曳组件(需求:全局&#xff0c;跨组件&#xff0c;跨数据)&#xff0c;我选择了react-dnd 概念 React DnD 是一组 React 高阶组件&#xff0c;我们在使用的时候只需要将目标元素进行包裹&#xff0c;就可以实现目标元素具有拖动或接受拖动的功能。…