Vite多环境配置与打包:

news2024/11/25 23:45:58

环境变量必须以VITE开头

1.VITE_BASE_API:

  • 在开发环境中设置为 /dev-api,这是一个本地 mock 地址,通常用于模拟后端接口。

2.VITE_ENABLE_ERUDA:

  • 设置为 "true",表示启用调试工具,通常是为了方便开发和调试。

3.VITE_PUBLIC_PATH:

  • 在开发环境中设置的打包路径为 http://192.168.10.7:8001,这可能是一个本地开发服务器的地址。

开发环境:

# baseUrl 
# /dev-api 为本地 mock 地址,不使用 mock 的话此处换为你的开发环境接口地址,例如 http://192.168.233.233
VITE_BASE_API = '/dev-api'

# 开发环境启用 cdn eruda 调试工具。若不启用,将 true 修改为 false 或其他任意值即可
VITE_ENABLE_ERUDA = "true"

# 线上环境平台打包路径
VITE_PUBLIC_PATH = http://192.168.10.1

线上生产环境:

线上生产环境的链接和打包路径通常是不同的。

  • VITE_BASE_API:这是指向后端 API 的基础 URL,通常用于应用程序与后端服务器通信。在你的例子中,它指向 http://192.168.10.7:8881/,这通常是一个内部或开发环境的地址。
  • VITE_PUBLIC_PATH:这是静态资源的公共路径,用于线上环境中访问静态文件。在你的例子中,它指向 http://8.154.36.180:8903,可能是一个用于托管静态资源的 CDN 或服务器。

Vite多环境配置与打包:

1. 安装依赖

npm install --save-dev cross-env

npm install --save-dev cross-env 命令用于安装 cross-env 这个工具,并将其作为开发依赖添加到你的项目中。下面是更详细的说明:

cross-env 的用途

  • 跨平台环境变量设置:

cross-env 允许你在不同操作系统(如 Windows 和 Unix/Linux)上统一设置环境变量。因为在 Windows 和 Unix 系统中设置环境变量的方式不同,使用 

cross-env 可以避免这些差异。

  • 常用场景:通常在 package.json 的 scripts 部分使用,用于设置环境变量后执行特定的命令。

示例:

在 package.json 中的 scripts 部分,你可能会看到类似的命令:

"scripts": {
  "start": "cross-env NODE_ENV=development node server.js",
  "build": "cross-env NODE_ENV=production webpack"
}

这意味着无论在 Windows 还是 Unix 系统上,你都可以使用 npm run start 或 npm run build 来启动开发或生产环境,而不必担心操作系统的差异。

如何检查项目中是否配置了 cross-env(忽略):

1.查看 package.json:

  • 打开项目根目录下的 package.json 文件,检查 devDependencies 是否包含 cross-env:

2..使用命令行:

  • 运行以下命令查看所有安装的包,包括开发依赖:
npm ls --dev
  • 在输出中查找 cross-env,如果找到了,说明项目已经配置了这个工具。

2. 配置环境变量

在项目根目录下创建 .env 文件,分别为不同环境创建不同的环境变量配置。例如:

  • .env.development:开发环境
  • .env.production:生产环境

在这些文件中,你可以设置不同的环境变量,例如 API 端点或其他服务的配置。

# .env
VITE_API_URL=https://api.example.com

# .env.development
VITE_API_URL=http://localhost:3000

# .env.production
VITE_API_URL=https://api.prod.example.com

3. 应用环境变量

在项目中,你可以通过 import.meta.env 访问这些环境变量。

在login登录页的时候,启动的时候可以打印到控制台查看运行的环境

// 在 Vue 组件或任何 JS 文件中

console.log(import.meta.env.MODE);

这个文件是自动生成的,后面会详细解释

4. 运行和构建项目

使用不同的环境变量运行和构建项目。在命令行中,你可以通过 --mode 选项指定环境。

# 开发环境
vite --mode development

# 生产环境
vite build --mode production

或者,你可以在 package.json 的脚本中定义不同的命令,以便更方便地运行和构建。

// package.json
{
  "scripts": {
    "dev": "vite --mode development",
    "build:dev": "vite build --mode development",
    "build:prod": "vite build --mode production"
  }
}

然后,你可以使用 npm 或 yarn 运行这些脚本(后续给老师,老师来对命令进行区分):

npm run dev
npm run build:dev
npm run build:prod

在 vite.config.ts中

使用了defineConfig 函数来定义构建选项。

export default defineConfig(({ mode }) => ({
  build: {
    rollupOptions: {
      output: {
        chunkFileNames: "static/js/[name]-[hash].js",
        entryFileNames: "static/js/[name]-[hash].js",
        assetFileNames: "static/[ext]/[name]-[hash].[ext]"
      }
    }
  }
}));
  • 默认环境:如果你没有在命令行中通过 --mode 参数显式指定模式,当你运行 vite build 时,默认情况下,Vite 将会使用 production(生产) 模式。
  • 在 production 模式下,Vite 会进行优化,以确保生成的构建文件适合生产环境。

可以通过在命令行中指定 --mode 参数来切换到其他环境,例如开发环境。


文件名:

ImportMetaEnv 和 ImportMeta 这些接口通常是在使用 Vite 和 TypeScript 时自动生成的。它们是 Vite 提供的类型定义,旨在帮助开发者在项目中更好地使用环境变量和模块功能。

具体情况:

  1. 自动生成:当你创建 Vite 项目时,Vite 会自动生成相关的类型定义文件,以便 TypeScript 能够正确识别 import.meta 对象的属性。
  2. 类型安全:这些接口提供了类型安全的方式来访问环境变量和其他模块元数据,减少了运行时错误的可能性。
  3. 更新:如果你更改了 Vite 配置中的环境变量,重新启动开发服务器后,这些类型定义会自动更新,以反映最新的配置。

接口详解:

1.ImportMetaEnv:

  • 描述了环境变量的类型。它可以包含任意数量的键值对,但至少有以下几个属性:
    • SSR: 布尔值,指示是否启用服务端渲染。
    • PROD: 布尔值,指示是否在生产模式。
    • DEV: 布尔值,指示是否在开发模式。
    • MODE: 当前运行模式(如 development 或 production)。
    • BASE_URL: 应用的基础 URL。

2.ImportMeta:

  • 描述了模块的元数据,包括:
    • glob: 动态导入多个模块的函数。
    • env: 当前环境变量的信息,类型为 ImportMetaEnv。
    • hot: 可选属性,用于热模块替换(HMR)。
    • url: 当前模块的完整路径。

模版:

interface ImportMetaEnv {
  [key: string]: any
  BASE_URL: string
  MODE: string
  DEV: boolean
  PROD: boolean
  SSR: boolean
}

interface ImportMeta {
  // 当前模块的 URL,指向模块文件的完整路径
  url: string;

  // 可选属性,用于支持热模块替换 (HMR)
  // 如果启用 HMR,该属性提供一个上下文对象
  readonly hot?: import('./hot').ViteHotContext;

  // 当前环境变量的信息
  // 包含构建时或运行时的环境配置,如 API URL、版本号等
  readonly env: ImportMetaEnv;

  // 动态导入多个模块的函数
  // 与 glob 模式结合使用,允许批量加载模块
  glob: import('./importGlob').ImportGlobFunction;
}

使用示例

在 Vite 项目中,可以直接使用这些接口来访问环境变量和模块信息。

// 假设在你的 TypeScript 文件中


// 访问环境变量

const apiUrl = import.meta.env.VITE_BASE_API; // 访问基础 API URL

const isDev = import.meta.env.DEV; // 判断是否在开发模式


// 打印环境信息

console.log(`API URL: ${apiUrl}`);

console.log(`Is Development: ${isDev}`);


// 使用 HMR(如果启用)

if (import.meta.hot) {
  import.meta.hot.accept((newModule) => {
    // 处理热更新
    console.log('Module updated:', newModule);
  });
}


// 使用动态导入

const loadComponent = async () => {
  const module = await import.meta.glob('./components/*.vue'); // 动态加载所有 Vue 组件
  console.log(module);
};
loadComponent();

前面提到,默认是生产环境指的是打包的默认模式:

默认模式说明

1.开发模式:

  • 当你运行 vite 命令或 npm run dev 时,Vite 默认使用开发模式。这是因为开发命令通常用于启动开发服务器,帮助开发者实时预览和调试应用。

2.生产模式:

  • 当你运行 vite build 时,Vite 默认会使用生产模式来构建应用。这里的 "默认" 指的是在没有显式指定 --mode 参数的情况下,Vite 会将 NODE_ENV 设置为 production。
总结
  • 开发命令(如 npm run dev)默认使用开发模式。
  • 构建命令(如 vite build)默认使用生产模式。

这两者并不冲突。在开发过程中,你通常使用开发模式,而在构建生产版本时,Vite 则使用生产模式。

所运行的时候默认是开发环境

如果你的 Vite 项目默认使用开发环境,通常是因为以下几个原因:

1.未指定环境模式
  • 默认情况下,当你运行 vite 或 vite build 命令时,如果没有显式指定 --mode 参数,Vite 会将 NODE_ENV 设置为 development。
  • 例如,运行以下命令时:
npm run dev

这将启动开发服务器,默认使用开发模式。

package.json 脚本配置

  • 在 package.json 中,可能会有类似以下的脚本:
"scripts": {
  "dev": "vite",  // 启动开发服务器
  "build": "vite build"  // 构建生产版本
}
  • 运行 npm run dev 会启动开发服务器,并使用开发环境。
2.vite.config.js 配置
  • 如果在 vite.config.js 中没有特别配置以指定环境,Vite 将默认为开发模式。
  • 你可以查看 vite.config.js,确认是否有设置 mode 的代码。
3.环境变量文件
  • Vite 支持使用环境变量文件(如 .env, .env.development, .env.production)来设置不同的环境变量。
  • 如果没有 .env.production 文件,或者在构建时没有指定 --mode production,则默认使用开发环境的配置。
4.命令行参数
  • 如果你希望在构建时使用生产环境,可以使用:
npm run build -- --mode production
总结

你的项目默认是开发环境,通常是因为没有显式指定其他环境模式。你可以通过查看 package.json、vite.config.js 和环境变量文件来确认和修改环境配置。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Elasticsearch学习笔记(六)使用集群令牌将新加点加入集群

随着业务的增长,陆续会有新的节点需要加入集群。当我们在集群中的某个节点上使用命令生成令牌时会出现报错信息。 # 生成令牌 /usr/share/elasticsearch/bin/elasticsearch-create-enrollment-token -s node出现报错信息: Unable to create enrollment…

VMware WorkStation Pro 15.5(低版本安装) 教学用

VMware WorkStation Pro 15.5(低版本安装) 教学用 文章目录 VMware WorkStation Pro 15.5(低版本安装) 教学用前言安装使用 前言 VMware Workstation Pro 15.5 是一款功能强大的桌面虚拟化软件,适用于在单台物理电脑上运行多个操作系统。它被广泛应用于软件开发、测…

【文献阅读】Attention Bottlenecks for Multimodal Fusion

Abstract 在多模态视频分类中,将各模态的最终表示或预测进行后期融合(“后期融合”)仍然是主流范式。为此,本文提出了一种基于 Transformer 的新型架构,该架构使用“融合瓶颈”在多个层次进行模态融合。与传统的成对自…

科研必备语料库

1. Corpus of Contemporary American English 链接:https://www.english-corpora.org/coca/ 2. Purdue Online Writing Lab 链接:https://owl.purdue.edu/owl/ 3. Academic Phrases and Vocabulary 链接:https://www.ref-n-write.com/blog…

IntelliJ IDE 插件开发 | (十三)自定义项目脚手架(下)

系列文章 本系列文章已收录到专栏,交流群号:689220994,也可点击链接加入。 前言 在上一篇文章中介绍了如何在 IDEA 中自定义项目脚手架,本文将介绍如何在WebStorm、PyCharm、CLion等其它 IntelliJ 主流平台中如何自定义项目脚手…

【论文速看】DL最新进展20241006-视频深度估计、3D、自监督学习

目录 【视频深度估计】【3D】【自监督学习】 【视频深度估计】 [TPAMI 2024] NVDS: Towards Efficient and Versatile Neural Stabilizer for Video Depth Estimation 论文链接:https://arxiv.org/pdf/2307.08695 代码链接:https://github.com/RaymondW…

地理空间数据存储与处理:MySQL空间数据类型的优化与应用!

在 MySQL 数据库中,空间数据类型用于存储和处理地理空间数据。这些数据类型允许我们在开发时可在数据库中存储和操作地理位置、几何形状和地理空间关系等信息。 一、什么是空间数据类型 MySQL 中的空间数据类型主要包括以下几种: GEOMETRY&#xff1a…

【无人水面艇路径跟随控制3】(C++)USV代码阅读: ROS包的构建和管理:包的依赖关系、包含目录、库文件以及链接库

【无人水面艇路径跟随控制3】(C)USV代码阅读: ROS包的构建和管理:包的依赖关系、包含目录、库文件以及链接库 写在最前面ROS是什么CMakeLists.txt总结详细解释CMake最低版本和项目名称编译选项查找catkin包catkin包配置包含目录添…

(刷题记录5)盛最多水的容器

盛最多水的容器 题目信息:题目思路(环境来自力扣OJ的C):暴力枚举:双指针:移动高度较高的指针移动高度较低的指针 复杂度:代码与注释:暴力枚举:双指针: 题目信息: 给定一…

windows 找不到文件 Microsoft Net Framework 3.5 windows Driver Foundation(WDF).exe

问题 正常更新windows 11的时候发现这个问题。 重启也无法完成下面的更新,重启之后还是显然要更新: 解决方法 中文网站没有找到解决方案。微软官网总是给不靠谱的解决方案。 从有关上看到一个印度语音的视频,用的方法可行。借鉴过来。 …

【机器学习】机器学习框架

机器学习框架是支持开发、训练、和部署机器学习模型的工具集和库,以下是一些主流的机器学习框架及其特点: 1. TensorFlow 特点: 由 Google 开发,支持从研究到生产的大规模部署,广泛应用于深度学习模型。优势: 强大的可扩展性&am…

golang gin入门

gin是个小而精的web开发框架 官方文档 安装 go get -u github.com/gin-gonic/gin最简单的起手代码 package mainimport ("net/http""github.com/gin-gonic/gin" )func main() {r : gin.Default()r.GET("/ping", func(c *gin.Context) {c.JSON…

【自用】王道文件管理强化笔记

文章目录 操作系统引导:磁盘初始化文件打开过程角度1文件的打开过程角度2 内存映射的文件访问 操作系统引导: ①CPU从一个特定主存地址开始,取指令,执行ROM中的引导程序(先进行硬件自检,再开机) ②)将磁盘的第一块–主引导记录读入内存&…

【机器学习】深度学习、强化学习和深度强化学习?

深度学习、强化学习和深度强化学习是机器学习的三个重要子领域。它们有着各自独特的应用场景和研究目标,虽然都属于机器学习的范畴,但各自的实现方式和侧重点有所不同。 1. 深度学习(Deep Learning) 深度学习是一种基于神经网络的…

2024 年在线翻译谁称霸?论文翻译场景大揭秘!

现在这世界,语言就是把我们连在一起的绳子,挺关键的。不管搞研究、做生意还是传文化,翻译得又快又准。2024年,翻译这行竞争挺猛的,各种在线翻译工具都挺拼的。咱们今天就聊聊论文翻译,瞅瞅谁能在这场翻译比…

Meta 发布 Quest 3S 头显及 AR 眼镜原型:开启未来交互新视界

简介 在科技的浪潮中,Meta 始终站在创新的前沿,不断为我们带来令人惊叹的虚拟现实和增强现实体验。2024 年 10 月 6 日,让我们一同聚焦 Meta 最新发布的 Quest 3S 头显及 AR 眼镜原型(Orion),探索这两款产品…

【Blender Python】5.Blender场景中的集合

概述 这里的“集合”是指Blender场景中的集合。你可以在“大纲视图”面板中看到 图标的,就是集合,可以看做是文件夹,用于分类和整理场景中的对象。 获取场景的集合 >>> C.scene bpy.data.scenes[Scene]>>> C.scene.coll…

nodejs 构建高性能服务器的关键技术

nodejs 构建高性能服务器的关键技术 演示地址 演示地址 源码地址 源码地址 获取更多 获取更多 在现代 Web 开发中,Node.js 已成为构建高性能、可扩展网络应用的首选平台之一。它的非阻塞 I/O 模型与事件驱动架构使其能够在处理大量并发请求时表现出色&#xff0…

环形缓冲区(Ring Buffer)在STM32 HAL库中的应用:防止按键丢失

环形缓冲区(Ring Buffer)又称为循环缓冲区或圆形队列,是一种数据结构,它用于管理固定大小的数据存储空间。环形缓冲区本质是一个一维数组,不过是收尾相连的,类比一条蛇咬自己尾巴。 环形缓冲区重要性&…

危机四伏|盘点紧盯我国的五大APT组织

毒云藤(APT-C-01) 命名:该组织是 360 独立发现的,并率先披露了该组织的部分相关信息符合 360 对 APT 组织就行独立命名的条件。 360 威胁情报中心将 APT-C-01 组织命名为“毒云藤”,主要是考虑了以下几方面的因素&…