前端面试题-Vite的打包速度为什么比Webpack快?

news/2024/10/11 11:18:57/

哈喽小伙伴们大家好!今天继续为大家分享一道面试题

大家都知道,Vite和Webpack是前端开发中用来构建项目的两个框架,Webpack是针对Vue2的,而Vite则是为vue3量身定制的,他们有哪些区别呢?为什么我们推荐使用Vite呢?Webpack又有哪些缺点呢?这篇文章我们来一探究竟。

Vite和Webpack的区别主要体现在以下几个方面.

1、开发模式的差异

在开发环境中,Webpack 是先打包再启动开发服务器,而 Vite 则是直接启动,然后再按需编译依赖文件。(大家可以启动项目后检查源码 Sources 那里看到)

这意味着,当使用 Webpack 时,所有的模块都需要在开发前进行打包,这会增加启动时间和构建时间。

而 Vite 则采用了不同的策略,它会在请求模块时再进行实时编译,这种按需动态编译的模式极大地缩短了编译时间,特别是在大型项目中,文件数量众多,Vite 的优势更为明显。

2、对ES Modules的支持

现代浏览器本身就支持 ES Modules,会主动发起请求去获取所需文件。Vite充分利用了这一点,将开发环境下的模块文件直接作为浏览器要执行的文件,而不是像 Webpack 那样先打包,再交给浏览器执行。这种方式减少了中间环节,提高了效率。

什么是ES Modules?

通过使用 export 和 import 语句,ES Modules 允许在浏览器端导入和导出模块。

当使用 ES Modules 进行开发时,开发者实际上是在构建一个依赖关系图,不同依赖项之间通过导入语句进行关联。

主流浏览器(除IE外)均支持ES Modules,并且可以通过在 script 标签中设置 type="module"来加载模块。默认情况下,模块会延迟加载,执行时机在文档解析之后,触发DOMContentLoaded事件前。

3、底层语言的差异

Webpack 是基于 Node.js 构建的,而 Vite 则是基于 esbuild 进行预构建依赖。esbuild 是采用 Go 语言编写的,Go 语言是纳秒级别的,而 Node.js 是毫秒级别的。因此,Vite 在打包速度上相比Webpack 有 10-100 倍的提升。

什么是预构建依赖?

预构建依赖通常指的是在项目启动或构建之前,对项目中所需的依赖项进行预先的处理或构建。这样做的好处在于,当项目实际运行时,可以直接使用这些已经预构建好的依赖,而无需再进行实时的编译或构建,从而提高了应用程序的运行速度和效率。

4、热更新的处理

在 Webpack 中,当一个模块或其依赖的模块内容改变时,需要重新编译这些模块。

而在 Vite 中,当某个模块内容改变时,只需要让浏览器重新请求该模块即可,这大大减少了热更新的时间。

综上所述,Vite和Webpack不论是在构建速度还是在开发模式层面都存在着显著的差异,导致它比Webpack更加轻量级,而且执行速度也更快,尤其是面对一些复杂度比较高的项目时,使用Vite无疑会很大幅度提升项目的性能,好啦,本期就到这儿,我们下期见~


http://www.ppmy.cn/news/1517544.html

相关文章

[翻译+笔记] Score-based generation: 通过数据分布的梯度进行生成建模

本次翻译笔记的是Yang Song博士的博客https://yang-song.net/blog/2021/score/. Yang Song博士提出了一系列的score-based的生成模型, 并对后续Diffusion model也产生了很深远的影响. 1. 引言 生成的基本任务是从某种程度上来估计或采样原始的数据分布. 现有的估计分布的方法大…

《中小学班主任》是什么级别的刊物?核心期刊吗?

《中小学班主任》是什么级别的刊物?核心期刊吗? 《中小学班主任》不是核心期刊,而是一本教育类省级刊物。 该刊旨在为全国中小学班主任提供学术指导,促进专业发展服务,是全国一线班主任和班主任研究者展示专业智慧和…

什么牌子的充电宝质量好?四款口碑极佳充电宝机型大盘点

在快节奏的现代生活中,充电宝已然成为我们不可或缺的随身物品。无论是日常通勤、外出旅行还是学习办公,一个质量上乘的充电宝能为我们的电子设备提供稳定可靠的电力支持。然而,面对市场上众多的充电宝品牌和机型,究竟什么牌子的充…

UE5学习笔记16-游戏模式中的一些事件,如何改变网格体和摄像头的碰撞

一、OnPostLogIn:此事件在玩家成功登录游戏后被调用 二、HandleStartingNuwplayer:在OnPostLogIn事件后被调用,可以用来定义新进入的玩家会发生什么 三、Spawn Default PawnAtTransform:这个事件触发游戏中实际的Pawn生成 四、…

K8S StatefulSet

Kubernetes StatefulSet 是 Kubernetes 中的一个核心概念,用于管理有状态应用的 Pod 部署和伸缩。与无状态应用相比,有状态应用通常需要持久化存储、唯一标识和有序部署等特性,而 StatefulSet 正是为了满足这些需求而设计的。 一、StatefulSet 的特点 稳定的唯一网络标识符…

09.IO流

一.常用的文件操作 1.如何创建文件: new File(String pathname) //根据路径构建一个File对象 new File(File parent,String child)/根据父目录文件子路径构建 new File(String parent,String child) //根据父目录子路径构建 public class fileCreat {public static…

flutter 开发中常用的 Widget

flutter 开发中常用的 Widget 原文地址 Container width 宽度height 高度margin 设置外间距padding 设置内间距alignment 对其方式decoration Decoration 对 Container 进行修饰 gradient 渐变boxShadow 阴影transform 设置形变constraints 设置 Contianer 最大、最小宽高col…

C++ 设计模式——迭代器模式

迭代器模式 C 设计模式——迭代器模式1. 主要组成成分2. 迭代器模式范例2.1 抽象迭代器2.2 抽象容器2.3 具体的迭代器2.4 具体的容器2.5 主函数示例 3. 迭代器 UML 图3.1 迭代器 UML 图解析 4. 迭代器模式的优点5. 迭代器模式的缺点6. 迭代器模式的适用场景7. 现代C中的迭代器总…