Vite 的工作流程

Vite 的工作流程基于其创新的 “预构建 + 按需加载” 机制,通过利用现代浏览器对原生 ES 模块的支持,显著提升了开发效率和构建速度。以下是其核心工作流程的详细分析:


一、开发环境工作流程

1. 启动开发服务器

  • 冷启动:通过 npm run dev 命令启动本地开发服务器,Vite 会快速初始化并启动一个基于 Koa 的服务器,无需打包所有模块,因此启动速度极快。
  • 预构建依赖:首次启动时,Vite 会对 node_modules 中的第三方依赖进行预构建(使用 esbuild),将 CommonJS 模块转换为 ESM 格式,并合并多个小文件以减少 HTTP 请求。预构建结果缓存到 node_modules/.vite 目录,后续启动直接复用。

2. 按需编译与请求拦截

  • 入口解析:浏览器请求入口文件(如 index.html)时,Vite 解析 HTML 中的 <script type="module">,识别入口模块(如 main.js)。
  • 动态编译:当浏览器请求某个模块(如 .vue.ts 文件)时,Vite 拦截请求并根据文件类型实时编译:
    • JavaScript/TypeScript:使用 esbuild 快速转换为浏览器兼容的 ESM 代码。
    • Vue/Svelte 单文件组件:通过插件(如 @vitejs/plugin-vue)拆解模板、样式和逻辑,分别编译为 JavaScript 和 CSS。
    • 静态资源:CSS、图片等文件通过特定插件处理(如添加哈希名或转换为 Base64)。

3. 热模块替换(HMR)

  • 实时更新:修改文件后,Vite 仅重新编译变更的模块,并通过 WebSocket 通知浏览器更新,无需刷新页面。例如,修改 Vue 组件时,仅替换该组件的代码,保留应用状态。
  • 优化策略:HMR 边界自动推断,避免 Webpack 中全量更新的性能问题。

二、生产环境工作流程

1. Rollup 打包

  • 代码优化:通过 npm run build 触发 Rollup 打包,进行 Tree Shaking、代码压缩(Terser)和代码分割,生成优化的静态文件(输出至 dist 目录)。
  • 静态资源处理:CSS 提取为独立文件,图片等资源根据配置选择内联或外部引用。

2. 预构建缓存复用

  • 依赖复用:生产构建时复用开发环境预构建的依赖缓存,减少重复编译时间。

三、核心机制解析

1. 原生 ESM 支持

  • 浏览器直接加载 ESM 模块,Vite 仅作为中间层处理模块请求,实现真正的按需加载。

2. 插件系统

  • 扩展能力:通过插件(如 vite-plugin-pwa)支持 PWA、SSR 等场景。插件可拦截请求、修改编译结果或扩展配置。
  • 常用插件示例
    // vite.config.js
    import vue from '@vitejs/plugin-vue';
    import legacy from '@vitejs/plugin-legacy';export default defineConfig({plugins: [vue(),legacy({ targets: ['defaults'] }) // 兼容旧浏览器]
    });
    

3. 配置灵活性

  • 别名与路径解析:支持自定义别名(如 @ 指向 src 目录)和扩展名自动补全。
  • 代理与服务器配置:开发服务器支持 HTTPS、端口设置和 API 请求代理。
    // vite.config.js
    export default defineConfig({server: {port: 3000,proxy: {'/api': { target: 'http://localhost:8000', changeOrigin: true }}}
    });
    

四、Vite 与 Webpack 的对比

特性ViteWebpack
启动速度毫秒级(按需编译)慢(全量打包)
HMR 效率仅更新变更模块需重新打包依赖链
生产构建Rollup(轻量高效)自建打包(功能全面但较重)
生态兼容性快速成长,支持主流框架成熟,插件丰富

五、适用场景与局限性

  • 适用场景:现代浏览器项目、需要快速迭代的 SPA、基于 Vue/React 的应用。
  • 局限性
    • 对旧版浏览器支持需额外插件(如 @vitejs/plugin-legacy)。
    • 生产环境仍需 Rollup 打包,复杂场景需手动优化。

通过上述流程,Vite 实现了开发效率与生产性能的平衡,成为现代前端工具链中的重要选择。如需深入配置或优化,可参考 Vite 官方文档。

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

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

相关文章

线性DP(动态规划)

线性DP的概念&#xff08;视频&#xff09; 学习线性DP之前&#xff0c;请确保已经对递推有所了解。 一、概念 1、动态规划 不要去看网上的各种概念&#xff0c;什么无后效性&#xff0c;什么空间换时间&#xff0c;会越看越晕。从做题的角度去理解就好了&#xff0c;动态规划…

MySQL中sql_mode的设置

■ 57版本原来配置 show variables like %sql_mode%; STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION ■ 修改配置文件 注释掉sql_mode&#xff0c;并重启&#xff0c;查看57版本的默认设置 ONL…

MCAL学习(1)——AutoSAR

1.了解AutoSAR及一些概念 AutoSAR是Automotive Open System Architecture ,汽车开放系统架构。 针对汽车ECU的软件开发架构。已经是汽车电子软件开发的标准。 OS服务&#xff1a;Freertos 整车厂&#xff08;OEM&#xff09;主要负责应用层算法 一级供应商&#xff1a;生产制…

Vue报错:Cannot read properties of null (reading ‘xxx‘)

一、报错问题 Cannot read properties of null (reading style)at patchStyle (runtime-dom.esm-bundler.js:104:22)二、错误排查 这类报错一般是在已经开发好后&#xff0c;后面测试时突然发现的&#xff0c;所以不好排查错误原因。 三、可能原因及解决方案 v-if 导致 在 …

25G 80km双纤BIDI光模块:远距传输的创新标杆

目录 一、产品优势&#xff1a;双纤与BIDI的独特价值 易天光通信25G SFP28 ZR 80KM 易天光通信25G SFP28 BIDI ZR 80KM 二、权威认证与技术突破 三、双纤与BIDI的核心差异解析 四、应用场景&#xff1a;驱动多领域高效互联 总结 在5G、云计算与数字化转型的推动下&#xff0c;光…

2025-05-06 学习记录--Python-注释 + 打印变量 + input输入

合抱之木&#xff0c;生于毫末&#xff1b;九层之台&#xff0c;起于累土&#xff1b;千里之行&#xff0c;始于足下。&#x1f4aa;&#x1f3fb; 一、注释 ⭐️ &#xff08;一&#xff09;、块注释 &#x1f36d; 举例&#xff1a; &#x1f330; # 打印数字 print(2025) …

基于mediapipe深度学习的眨眼检测和计数系统python源码

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 5.算法完整程序工程 1.算法运行效果图预览 (完整程序运行后无水印) 2.算法运行软件版本 人工智能算法python程序运行环境安装步骤整理_本地ai 运行 python-CSDN博客 3.部分核心程序 &…

怎样通过API 实现python调用Chatgpt,gemini

怎样通过API 实现python调用Chatgpt,gemini 以下为你详细介绍如何设置和调用这些参数,以创建一个类似的 ChatCompletion 请求: 1. 安装依赖库 如果你使用的是 OpenAI 的 API 客户端,需要先安装 openai 库。可以使用以下命令进行安装: pip install openai2. 代码示例 …

Linux 下MySql主从数据库的环境搭建

测试环境&#xff1a;两台服务器&#xff0c;Mysql版本 8.0&#xff0c;linux版本&#xff1a;Ubuntu 20.04.3&#xff1b; 1.在两台服务器上安装MySql&#xff1b; 2.选一台作为主服务器&#xff0c;在主服务器上以root用户进入Mysql&#xff0c;执行以下语句&#xff1a; …

力扣1812题解

记录 2025.5.7 题目&#xff1a; 思路&#xff1a; 从左下角开始&#xff0c;棋盘的行数和列数&#xff08;均从 1 开始计数&#xff09;之和如果为奇数&#xff0c;则为白色格子&#xff0c;如果和为偶数&#xff0c;则为黑色格子。 代码&#xff1a; class Solution {pu…

适合java程序员的Kafka消息中间件实战

创作的初心&#xff1a; 我们在学习kafka时&#xff0c;都是基于大数据的开发而进行的讲解&#xff0c;这篇文章为java程序员为核心&#xff0c;助力大家掌握kafka实现。 什么是kafka: 历史&#xff1a; 诞生与开源&#xff08;2010 - 2011 年&#xff09; 2010 年&#xf…

PDF智能解析与知识挖掘:基于pdfminer.six的全栈实现

前言 在数字化信息爆炸的时代&#xff0c;PDF&#xff08;便携式文档格式&#xff09;作为一种通用的电子文档标准&#xff0c;承载着海量的结构化与非结构化知识。然而&#xff0c;PDF格式的设计初衷是用于展示而非数据提取&#xff0c;这使得从PDF中挖掘有价值的信息成为数据…

Python爬虫+代理IP+Header伪装:高效采集亚马逊数据

1. 引言 在当今大数据时代&#xff0c;电商平台&#xff08;如亚马逊&#xff09;的数据采集对于市场分析、竞品监控和价格追踪至关重要。然而&#xff0c;亚马逊具有严格的反爬虫机制&#xff0c;包括IP封禁、Header检测、验证码挑战等。 为了高效且稳定地采集亚马逊数据&am…

架构思维:探讨架构师的本质使命

文章目录 软件工程1. 软件工程的定义与核心目标2. 软件工程 vs. 软件项目管理3. 软件工程的两大特性4. 软件工程的关键活动与方法论5. 架构师在软件工程中的职责架构师的职责和思维架构师心性修炼三大核心能力架构设计的基本准则 团队共识“设计文档”的统一结构框架阅读他人代…

QT设计权限管理系统

Qt能够简单实现系统的权限设计 首先我们需要一个登陆界面 例如这样 然后一级权限&#xff0c;可以看到所有的内容&#xff0c;不设置菜单栏的隐藏。 然后其他权限&#xff0c;根据登陆者的身份进行菜单栏不同的展示。 菜单栏的隐藏代码如下&#xff1a; ui->actionuser-…

Debezium 架构详解与实战示例

Debezium 架构详解与实战示例 1. 整体架构图 #mermaid-svg-tkAquOxA2pylXzON {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-tkAquOxA2pylXzON .error-icon{fill:#552222;}#mermaid-svg-tkAquOxA2pylXzON .error-t…

Qt天气预报系统更新UI界面

Qt天气预报系统更新UI界面 1、创建各个小部分列表2、定义一个更新UI函数2.1 实现更新UI界面函数 1、创建各个小部分列表 QList<QLabel *> weekList; //星期 QList<QLabel *> dateList; //日期QList<QLabel *> weatherL…

AWS MCP Servers

文章目录 一、关于 AWS MCP Servers什么是模型上下文协议&#xff08;MCP&#xff09;以及它是如何与AWS MCP服务器协同工作的&#xff1f;为什么选择MCP服务器&#xff1f; 二、可用 Servers核心MCP服务器AWS 文档服务器亚马逊 Bedrock 知识库检索 MCP 服务器AWS CDK MCP 服务…

python如何把pdf转word

在Python中将PDF转换为Word文档&#xff08;.docx&#xff09;比反向转换&#xff08;Word转PDF&#xff09;更具挑战性&#xff0c;因为PDF是固定格式&#xff0c;而Word是可编辑格式。以下是几种可行的方法及详细步骤&#xff1a; 方法1&#xff1a;使用 pdf2docx 库 pdf2do…

NLP 和大模型技术路线

transformers快速入门 NLP 和大模型技术路线 在自然语言处理&#xff08;NLP&#xff09;和大模型领域&#xff0c;技术路线的学习应该从基础开始&#xff0c;逐步深入到更高阶的应用和优化技术。本文将详细介绍相关技术点的学习顺序&#xff0c;以及每个技术点的关键学习内容…