process.env 管理 Vue 项目的环境变量(Vue项目中环境变量的配置及调用)

简述:在构建 Vue 应用时,管理配置是开发中的一个重要部分。不同的环境(如开发、测试和生产)往往需要不同的配置,例如 API、 基础 URL、第三方服务的密钥等。使用环境变量可以帮助我们更好地管理这些配置。这里将介绍如何在 Vue 项目中使用 process.env 来管理环境变量。这里来记录一下



⭐什么是 process.env?

process.env 是 Node.js 的一个全局对象,它包含了系统环境变量。这些变量可以在应用程序的运行时访问,允许开发人员根据不同的环境设置不同的配置。通过使用 process.env 管理环境变量,可以使 Node.js 应用程序的配置更加灵活和安全。


⭐为什么要在项目中使用环境变量?

环境变量在项目中的使用有多个重要原因,包括安全性、灵活性和配置管理。以下是详细解释:

1. 安全性

将敏感信息如 API 密钥、数据库密码和其他机密数据存储在环境变量中,可以显著提高应用的安全性。避免将这些敏感信息硬编码在源代码中可以减少数据泄露的风险:

  • 避免暴露机密:环境变量使得敏感信息不直接出现在代码库中,降低了信息泄露的风险。
  • 保护配置文件:通过环境变量可以避免将敏感配置暴露在版本控制系统中,从而增强了代码的安全性。

2. 灵活性

环境变量提供了灵活的配置管理方式,使得在不同的环境中使用不同的配置变得更加方便:

  • 无缝切换环境:通过设置不同的环境变量,可以轻松地在开发、测试、预生产和生产环境之间切换,而无需修改代码。
  • 减少代码修改:只需更改环境变量而不是修改代码文件,可以迅速调整配置,以适应不同的需求和环境。

3. 配置管理

环境变量提供了一种统一的配置管理方式,使得应用程序的配置更加可控和一致:

  • 集中管理:将所有环境配置集中在环境变量中,使得管理和维护配置变得更加简洁和高效。
  • 环境隔离:不同的环境可以有独立的配置文件,确保在一个环境中的设置不会影响到其他环境。
  • 简化部署:在部署时,只需根据目标环境加载相应的环境变量文件,从而简化了配置和部署过程。


⭐如何在 Vue 项目中使用环境变量?

一. 创建环境文件

在 Vue 项目根目录下,可以创建多个环境文件,例如:

.env                                    默认环境配置

.env.development               开发环境配置

.env.test:                          测试环境配置

.env.staging                        预生产环境配置

.env.production                   生产环境配置

这些文件的内容格式如下:

VUE_APP_API_URL=https://api.example.com


VUE_APP_SECRET_KEY=your_secret_key

这里所有自定义环境变量的名称必须以 VUE_APP_ 为前缀。Vue CLI 只会嵌入以 VUE_APP_ 为前缀的变量,以确保这些变量不会泄露应用程序运行时所需的其他环境变量。


二. 配置不同环境的变量

根据不同的环境,可以在相应的环境文件中配置不同的变量。例如:

.env.development 中:

VUE_APP_API_URL=https://dev.api.example.com


VUE_APP_SECRET_KEY=dev_secret_key

.env.test 中:

VUE_APP_API_URL=https://test.api.example.com


VUE_APP_SECRET_KEY=test_secret_key

.env.staging 中:

VUE_APP_API_URL=https://staging.api.example.com


VUE_APP_SECRET_KEY=staging_secret_key

.env.production 中:

VUE_APP_API_URL=https://api.example.com


VUE_APP_SECRET_KEY=prod_secret_key


三. 在 JS 文件中访问环境变量

在 Vue 组件或 JavaScript 文件中,可以通过 process.env 对象来访问这些环境变量。例如:

// 获取当前环境变量 NODE_ENV 的值,通常用于区分不同的运行环境(如开发、测试、生产)。
const env = process.env.NODE_ENV;

console.log(`Running in ${env} mode`);

这里从 process.env 对象中获取名为 NODE_ENV 的环境变量的值,并将其赋值给 env 变量。这里使用模板字符串打印出当前的运行环境模式。假设 NODE_ENV 的值是 development,这行代码将输出 Running in development mode


四. 启动应用时加载环境变量

当你启动 Vue 应用时,Vue CLI 会根据当前环境自动加载相应的环境文件。例如:

npm run serve # 会加载 .env 和 .env.development 文件


npm run build # 会加载 .env 和 .env.production 文件

  • npm run serve:在开发模式下启动开发服务器时,Vue CLI 会默认加载 .env.env.development 文件。这些文件中的环境变量会在开发过程中生效,用于配置开发环境所需的参数。

  • npm run build:在构建生产版本时,Vue CLI 会默认加载 .env.env.production 文件。这些文件中的环境变量会在构建生产版本时生效,用于配置生产环境所需的参数。

当然需要额外配置,为了更好地管理不同环境的启动命令,我们可以在 package.json 中配置多种启动命令,这样可以更方便地在不同环境中启动和构建应用。以下是详细的配置方法:

配置 package.json

package.json 中配置不同环境的启动和构建命令。使用 cross-env 包来设置 NODE_ENV,以确保在不同操作系统上正确设置环境变量。

首先,安装 cross-env

npm install cross-env --save-dev

// 或者

cnpm install cross-env --save-dev

然后,在 package.json 中添加如下脚本:

{
  "scripts": {
    "serve": "vue-cli-service serve",
    "build": "vue-cli-service build",
    "serve:dev": "cross-env NODE_ENV=development vue-cli-service serve",
    "serve:test": "cross-env NODE_ENV=test vue-cli-service serve",
    "serve:staging": "cross-env NODE_ENV=staging vue-cli-service serve",
    "serve:prod": "cross-env NODE_ENV=production vue-cli-service serve",
    "build:dev": "cross-env NODE_ENV=development vue-cli-service build",
    "build:test": "cross-env NODE_ENV=test vue-cli-service build",
    "build:staging": "cross-env NODE_ENV=staging vue-cli-service build",
    "build:prod": "cross-env NODE_ENV=production vue-cli-service build"
  }
}

这些命令允许你在不同环境下启动和构建应用:

  • npm run serve:dev:启动开发环境
  • npm run serve:test:启动测试环境
  • npm run serve:staging:启动预生产环境
  • npm run serve:prod:启动生产环境
  • npm run build:dev:构建开发环境
  • npm run build:test:构建测试环境
  • npm run build:staging:构建预生产环境
  • npm run build:prod:构建生产环境

然后,确保正确加载环境文件

Vue CLI 会根据 NODE_ENV 自动加载相应的环境文件。例如:

  • 如果 NODE_ENV 设置为 development,Vue CLI 会加载 .env.env.development 文件。
  • 如果 NODE_ENV 设置为 test,Vue CLI 会加载 .env.env.test 文件。
  • 如果 NODE_ENV 设置为 staging,Vue CLI 会加载 .env.env.staging 文件。
  • 如果 NODE_ENV 设置为 production,Vue CLI 会加载 .env.env.production 文件。

通过创建不同的环境文件并配置启动命令,可以在 Vue 项目中轻松管理和加载不同环境的变量。这使得应用程序的配置更加灵活和安全,适用于开发、测试、预生产和生产等不同环境。


五. 使用环境变量配置 Axios 详细

假设我们使用 Axios 进行 HTTP 请求,可以使用环境变量配置 Axios 的基础 URL。步骤如下:

1. 安装 Axios

首先,我们需要安装 Axios 作为 HTTP 客户端工具:

npm install axios
// 或者
cnpm install axios

2. 创建 Axios 实例

接下来,我们创建一个 Axios 实例,并配置基础路径:

// 该文件目录:src/utils/request.js

// 引入 axios 库,用于发送 HTTP 请求
import axios from 'axios';

// 创建 Axios 实例
const service = axios.create({
  // ⭐使用 process.env. 环境变量配置基础路径
  // baseURL 指定了请求的基础 URL,通常从环境变量中读取
  baseURL: process.env.VUE_APP_BASE_API, 
  // 请求超时时间设置为 5000 毫秒(5 秒)
  timeout: 5000, // 请求超时时间
});

// 请求拦截器
service.interceptors.request.use(
  config => {
    // 在请求发送之前可以对请求进行配置,如添加请求头、修改请求参数等
    // 例如,可以在这里添加认证 token
    return config;
  },
  error => {
    // 请求错误时,打印错误信息
    console.error('请求错误:', error);
    // 返回一个拒绝的 Promise,以便处理请求错误
    return Promise.reject(error);
  }
);

// 响应拦截器
service.interceptors.response.use(
  response => {
    // 在收到响应数据后,可以对响应数据进行处理
    // 比如,可以在这里处理统一的响应格式
    return response.data;
  },
  error => {
    // 响应错误时,打印错误信息
    console.error('响应错误:', error);
    // 返回一个拒绝的 Promise,以便处理响应错误
    return Promise.reject(error);
  }
);

// 导出 Axios 实例,以便在其他模块中使用
export default service;

这里在配置baseURL时,直接使用process.env.VUE_APP_BASE_API来设置基本路径。在启动开发服务器,运行 npm run serve 时,Vue CLI 会加载 .env.env.development 文件中的环境变量。此时,process.env.VUE_APP_BASE_API 的值会被设置为 .env.development 文件中定义的值,如果 .env.development 中没有定义,则使用 .env 文件中的值。

3. 创建 http.js 文件

并在 src/api 目录下创建一个 http.js 文件,并添加以下内容:

// 该文件目录:src/api/http.js

// 引入之前创建的 Axios 实例
import request from "@/utils/request";

/**
 * 获取图表数据的请求方法
 * @param {Object} data - 请求数据
 * @returns {Promise} - 返回一个 Promise 对象
 */
export function toDaySituation(data) {
    return request({
        url: '/res/situation/overview', // API 端点,指定了请求的路径
        method: 'post', // 请求方法,表示使用 POST 请求
        data // 请求数据,传递给 API 的请求体
    });
}

4. 在组件中调用请求方法

接下来,我们在组件中调用 callModelType方法,来请求图表数据并处理响应。例如:

// 请入请求数据的函数
import { toDayModeltype } from '@/api/http.js';

methods: {

    // 模型类型事件
    callModelType(value) {
      // 设置加载状态为 true
      this.tableLoading = true;

      // 调用 PatchList 方法并传递参数
      toDayModeltype(this.modelParams, this.params)
        .then((res) => {
          // 处理请求成功的情况
          if (res.code === 200) {
            // 设置延迟以模拟异步操作
            setTimeout(() => {
              this.tableLoading = false; // 将加载状态设置为 false
            }, 100);
            // 赋值操作,将获取的数据保存到变量
            const data = res.rows;     
          }
        })
        .catch(() => {
          // 处理请求失败的情况
          this.tableLoading = false; // 将加载状态设置为 false
        })
        .finally(() => {
          // 无论请求成功还是失败,都会执行这里的代码
          this.tableLoading = false; // 将加载状态设置为 false
        });
    },

},

created() {
    // 组件创建时调用 callModelType方法
    this.callModelType();
},


六. 在组件中使用环境变量

在 Vue 组件中,可以直接使用环境变量。例如:

<template>
  <div>
    <!-- 显示 API URL -->
    <p>API URL: {{ apiUrl }}</p>
  </div>
</template>

<script>
export default {
  data() {
    return {
      // 从环境变量中读取 API URL
      apiUrl: process.env.VUE_APP_API_URL, // 读取环境变量 VUE_APP_API_URL 的值
    };
  },
};
</script>


总结

通过在 Vue 项目中使用 process.env 管理环境变量,可以使配置管理更加灵活和安全。无论是在开发、测试、预生产还是生产环境中,环境变量都提供了一种有效的方法来管理应用程序的配置。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/779289.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

2 极/2 零 (2P2Z) 补偿器

极/2 零 &#xff08;2P2Z&#xff09; 补偿器是模拟 II 型控制器的数字实现。它是一种滤波器&#xff0c;通过考虑两个极点和一个零点&#xff0c;将特定的增益和相位升压引入系统。您必须战略性地选择每个极点和零点的频率位置&#xff0c;这将有助于实现所需的系统性能。在该…

当需要对大量数据进行排序操作时,怎样优化内存使用和性能?

文章目录 一、选择合适的排序算法1. 快速排序2. 归并排序3. 堆排序 二、数据结构优化1. 使用索引2. 压缩数据3. 分块排序 三、外部排序1. 多路归并排序 四、利用多核和并行计算1. 多线程排序2. 使用并行流 五、性能调优技巧1. 避免不必要的内存复制2. 缓存友好性3. 基准测试和性…

手把手教你从零开始构建 AI 视频生成模型

在 GitHub 上发现一篇教程&#xff0c;作者详细介绍了如何使用 Python 语言&#xff0c;从零开始构建一个文本到视频生成模型。 涵盖了从理解理论概念到架构编码&#xff0c;最终实现输入文本提示即可生成视频的全过程。 相关链接 GitHub&#xff1a;github.com/FareedKhan-…

PD协议诱骗芯片,XSP08Q,XSP16应用笔记

XSP08Q是3C数码或小家电产品的Type-C接口控制芯片&#xff0c;它负责和PD充电器通讯&#xff0c;获取充电器的快充电压档位&#xff0c;如5V4A&#xff0c;9V3A&#xff0c;12V2A&#xff0c;15V3A&#xff0c;20V5A等等。 XSP08Q支持PD协议&#xff0c;BC1.2协议&#xff0c;Q…

Rakis: 免费基于 P2P 的去中心化的大模型

是一个开源的&#xff0c;完全在浏览器中运行的去中心化 AI 推理网络&#xff0c;用户无需服务器&#xff0c;打开即可通过点对点网络使用 Llama-3、Mistral、Gemma-2b 等最新开源模型。 你可以通过右上角的 Scale Worker &#xff0c;下载好模型后挂机就能作为节点加入到这个…

【全面讲解下Foxit Reader】

&#x1f3a5;博主&#xff1a;程序员不想YY啊 &#x1f4ab;CSDN优质创作者&#xff0c;CSDN实力新星&#xff0c;CSDN博客专家 &#x1f917;点赞&#x1f388;收藏⭐再看&#x1f4ab;养成习惯 ✨希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出…

便携式气象站:探索自然的智慧伙伴

在探索自然奥秘、追求科学真理的道路上&#xff0c;气象数据始终是我们不可或缺的指引。然而&#xff0c;传统的气象站往往庞大而笨重&#xff0c;难以在偏远地区或移动环境中灵活部署。 便携式气象站&#xff0c;顾名思义&#xff0c;是一种小巧轻便、易于携带和安装的气象观测…

农资销售网站-计算机毕业设计源码54432

目录 摘要 Abstract 1绪论 1.1研究背景 1.2研究意义 1.3论文结构与章节安排 2农资销售网站系统分析 2.1可行性分析 2.1.1技术可行性分析 2.1.2经济可行性分析 2.1.3法律可行性分析 2.2系统功能分析 2.2.1功能性分析 2.2.2非功能性分析 2.3系统用例分析 2.4系统流…

比赛获奖的武林秘籍:03 好的创意选取-获得国奖的最必要前提

比赛获奖的武林秘籍&#xff1a;03 好的创意选取-获得国奖的最必要前提 摘要 本文主要介绍了大学生电子计算机类比赛和创新创业类比赛创意选取的重要性&#xff0c;并列举了好的创意选取和坏的创意选取的例子&#xff0c;同时说明了好的创意选取具有哪些特点&#xff0c;同时…

Tkinter布局助手

免费的功能基本可以满足快速开发布局&#xff0c; https://pytk.net/ iamxcd/tkinter-helper: 为tkinter打造的可视化拖拽布局界面设计小工具 (github.com) 作者也把项目开源了&#xff0c;有兴趣可以玩玩

Java中线程的常用方法(并发编程基础)

Java中线程的常用方法 sleep 调用sleep会让当前线程从Running进入TIMED WAITING状态其它线程可以使用 interrupt 方法打断正在睡眠的线程,这时sleep方法会抛出InterruptedException睡眠结束后的线程未必会立刻得到执行建议用TimeUnit的sleep代替Thread的sleep来获得更好的可读…

如何在PD虚拟机中开启系统的嵌套虚拟化功能?pd虚拟机怎么用 Parallels Desktop 19 for Mac

PD虚拟机是一款可以在Mac电脑中运行Windows系统的应用软件。使用 Parallels Desktop for Mac 体验 macOS 和 Windows 的最优性能&#xff0c;解锁强大性能和无缝交互。 在ParallelsDesktop&#xff08;PD虚拟机&#xff09;中如何开启系统的嵌套虚拟化功能&#xff1f;下面我们…

vulhub-activemq(CVE-2015-5254)

Apache ActiveMQ 5.13.0版本之前到5.x版本的安全漏洞&#xff0c;该程序引起的漏洞不限制代理中可以序列化的类。远程攻击者可以制作一个特殊的序列化 Java 消息服务 (JMS) ObjectMessage 对象&#xff0c;利用该漏洞执行任意代码。 Apache ActiveMQ 5.x ~ Apache ActiveMQ 5.1…

【人工智能】-- 智能机器人

个人主页&#xff1a;欢迎来到 Papicatch的博客 课设专栏 &#xff1a;学生成绩管理系统 专业知识专栏&#xff1a; 专业知识 文章目录 &#x1f349;引言 &#x1f349;机器人介绍 &#x1f348;机器人硬件 &#x1f34d;机械结构 &#x1f34d;传感器 &#x1f34d;控…

基于Android Studio电影购票系统

目录 项目介绍 图片展示 运行环境 获取方式 项目介绍 主要实为了方便用户随时随地进行电影购票。在配色方面选择了一些富有电影元素的颜色。主要能够实现的功能与流程为&#xff1a; 1.用户首先需要注册用户名填写密码。 2.用户可以用之前注册的用户名和密码进行登录。 3.登…

键盘异常的检测与解决方案

今天对象用Word写文档&#xff0c;按下Ctrl的时候&#xff0c;页面不停地上下滑动&#xff0c;导致无法正常编辑文本。 重启之后&#xff0c;仍然无法解决&#xff0c;推断是键盘坏了。 但是当按下Fn或其他功能键&#xff0c;焦点移除&#xff0c;页面就不会再抖动了。 现在…

[CP_AUTOSAR]_分层软件架构_内容详解

目录 1、软件分层内容1.1、Microcontroller Abstraction Layer1.2、ECU Abstraction Layer1.2.1、I/O HW Abstraction1.2.2、Communication Hardware Abstraction1.2.3、Memory Hardware Abstraction1.2.4、Onboard Device Abstraction1.2.5、Crypto Hardware Abstraction 1.3、…

Docker安装遇到问题:curl: (7) Failed to connect to download.docker.com port 443: 拒绝连接

问题描述 首先&#xff0c;完全按照Docker官方文档进行安装&#xff1a; Install Docker Engine on Ubuntu | Docker Docs 在第1步&#xff1a;Set up Dockers apt repository&#xff0c;执行如下指令&#xff1a; sudo curl -fsSL https://download.docker.com/linux/ubu…

超赞的8款生活APP推荐!

AI视频生成&#xff1a;小说文案智能分镜智能识别角色和场景批量Ai绘图自动配音添加音乐一键合成视频https://aitools.jurilu.com/每天都会有几十个应用程序发布&#xff0c;一款用得好的应用程序可以极大地丰富您的生活。对于那些不知道哪个应用程序适合您以及您需要哪个应用程…

将excel表格转换为element table(下)

在‘将excel表格转换为element table(上)’我们把excel 转换后通过数据重构绑定到了element table上&#xff0c;现在要做的就是根据源文件进行行列进行合并操作 先看看最终处理的结果 这里在一步步分析实现步骤。 先分析一下合并的逻辑 大致思路理理如上。 思路有了接下来…