前端构建工具vite的优势


1. 极速冷启动

  • Vite 使用原生 ES 模块 (ESM) 在开发环境下进行工作。相比于传统构建工具需要打包所有的文件,Vite 只在浏览器请求模块时动态加载所需的文件。
  • 无打包冷启动:无需预先打包,项目启动非常快,尤其对于大型项目效果更明显。

2. 模块热替换 (HMR) 更加快速

  • Vite 内置了高效的模块热替换 (Hot Module Replacement, HMR) 功能,更新某个模块时,Vite 只会精确地替换被更改的模块,不会像传统构建工具一样重新构建整个应用。
  • HMR 响应更快:当你在开发时修改文件,Vite 能快速更新页面内容,极大提升开发体验。

3. 按需编译

  • 在开发环境下,Vite 会根据浏览器的请求按需编译代码,而不是一次性编译所有文件。这意味着如果某些模块从未被导入,就不会被编译,进一步提高了开发时的性能。

4. 更好的现代化支持

  • Vite 默认支持现代浏览器,利用原生 ES 模块和最新的 JavaScript 特性,不需要为老旧浏览器生成复杂的代码或 polyfill。这使得 Vite 的编译输出更轻量。
  • 轻量级的生产构建:生产环境使用 Rollup 打包,确保最终打包质量且优化文件大小。

5. 内置优化

  • Vite 内置对 TypeScript、JSX、CSS、JSON 等的支持,无需额外配置即可使用现代前端特性。
  • 自动依赖预构建:Vite 会自动预构建较大的依赖包(例如 React、Vue 等),减少了这些依赖的解析开销,加快页面加载速度。

6. 插件生态与扩展性

  • Vite 有着灵活的插件机制,基于 Rollup 插件系统,支持大部分 Rollup 插件,开发者可以方便地扩展功能。
  • 支持多种框架:Vite 原生支持 Vue、React、Preact 等框架,并有很好的 TypeScript 支持。

7. 优化的生产环境构建

  • Vite 在生产模式下会使用 Rollup 进行打包,Rollup 是一个成熟且优化的打包工具,能生成体积小、性能优良的打包文件。
  • 轻量级打包:通过树摇和代码分割等优化技术,生成的最终构建包体积更小、加载更快。

8. CSS/JS 处理优化

  • Vite 内置了对 CSS 和 JS 的处理优化,CSS 可以按需加载,JS 代码可以模块化分割,且支持动态导入。

9.适用场景

Vite 特别适合那些希望快速开发、追求现代工具链的开发者,尤其是使用 Vue、React、Svelte 等现代框架的项目。
vite和webpack构建对比图
vite:

webpack:


10.Vite 和 Webpack优缺点

1. 启动速度
  • Vite
    • 优点:Vite 利用浏览器的原生 ES 模块(ESM)加载机制,不需要对整个项目进行打包,因此启动速度极快。它只会在浏览器请求某个模块时编译相关文件,尤其在大型项目中,冷启动时间大大缩短。
    • 缺点:Vite 的这种按需编译模式在开发环境中非常快,但在不支持原生 ES 模块的旧浏览器中,可能需要特殊处理。
  • Webpack
    • 优点:Webpack 在启动时需要对整个项目进行一次完整打包,启动时间较长,但它会缓存构建结果,重复构建时速度会有所提升。
    • 缺点:冷启动时间较慢,尤其是对于大型项目,Webpack 启动时间可能会显著拖延开发效率。
2. 模块热替换(HMR)
  • Vite
    • 优点:由于 Vite 采用了基于 ES 模块的动态加载机制,它可以精确替换被修改的模块,HMR 速度非常快,通常是毫秒级响应。
    • 缺点:HMR 的性能与项目模块的复杂度有关,对于特别复杂的项目,HMR 的维护可能需要调整。
  • Webpack
    • 优点:Webpack 也支持模块热替换,且经过多年的优化和实践,HMR 已经相当成熟,适用于各类场景。
    • 缺点:由于 Webpack 打包方式的特点,模块更新时,可能需要替换更多的文件,导致 HMR 速度较慢,特别是在大规模项目中。
3. 开发模式
  • Vite
    • 优点:在开发模式下,Vite 不会打包整个应用,它基于 ESM 直接提供服务,因此开发时的响应速度非常快。
    • 缺点:需要现代浏览器支持 ES 模块。如果需要兼容老版本浏览器,可能需要额外配置。
  • Webpack
    • 优点:Webpack 使用一个开发服务器(如 webpack-dev-server)来提供开发环境,经过多年的完善,其开发模式能够支持复杂的构建和兼容性处理。
    • 缺点:由于需要打包整个应用,构建过程较慢,尤其在项目规模变大的情况下。
4. 生产环境打包
  • Vite
    • 优点:Vite 在生产环境中使用 Rollup 进行打包,具有更细粒度的代码分割和更优化的打包结果。最终生成的打包文件更轻量、加载更快。
    • 缺点:Rollup 对某些特殊构建需求或插件生态的支持可能没有 Webpack 那么成熟,可能需要手动调整或额外配置。
  • Webpack
    • 优点:Webpack 通过多年的发展,生产环境的构建功能非常强大,支持代码分割、懒加载、Tree Shaking、插件系统等多种优化技术,生态非常丰富。
    • 缺点:Webpack 的配置复杂,打包速度可能相对较慢,尤其在处理大规模应用时,构建时间可能较长。
5. 配置复杂度
  • Vite
    • 优点:Vite 提供了开箱即用的默认配置,极大简化了开发者的工作。特别是对于 Vue、React 等现代框架,Vite 原生支持,无需复杂的配置即可启动。
    • 缺点:Vite 的插件生态尚在发展中,部分复杂场景下,可能需要开发者深入了解 Rollup 及其插件系统进行定制化配置。
  • Webpack
    • 优点:Webpack 提供了强大的自定义配置能力,可以处理几乎所有的前端需求,且拥有丰富的插件和 Loader 来扩展功能。
    • 缺点:Webpack 的配置较为复杂,新手开发者需要花费较多时间来学习和调试其配置文件。
6. 依赖处理
  • Vite
    • 优点:Vite 会自动预构建依赖,使用 esbuild 来处理依赖的编译,esbuild 使用 Go 编写,编译速度极快,因此依赖处理非常高效。
    • 缺点:对于一些非常复杂或较旧的依赖库,可能需要额外处理其兼容性问题。
  • Webpack
    • 优点:Webpack 的依赖处理机制较为成熟,兼容性好,能够很好地处理不同版本、不同格式的依赖。
    • 缺点:依赖处理和打包时间较长,特别是当项目依赖较多时,Webpack 的构建时间可能会明显增加。
7. 插件生态
  • Vite
    • 优点:Vite 的插件系统基于 Rollup 插件机制,且具有很强的扩展性。Vite 的现代化设计使其插件开发较为简便,生态正在快速成长。
    • 缺点:虽然插件生态在快速发展,但相对于 Webpack,Vite 的插件数量和成熟度仍然稍显不足。
  • Webpack
    • 优点:Webpack 拥有非常成熟的插件生态系统,几乎可以找到适用于任何需求的插件,支持从性能优化、代码分割、到兼容性处理等各种场景。
    • 缺点:插件多样性和配置复杂度可能会增加开发者的学习成本,某些插件可能需要额外调整配置才能正常工作。
8. 兼容性
  • Vite
    • 优点:Vite 专注于现代浏览器的开发体验,开发时使用的是原生 ES 模块,因此对于现代开发有非常好的支持。
    • 缺点:如果需要支持 IE11 等老旧浏览器,可能需要进行一些额外的 polyfill 和配置。
  • Webpack
    • 优点:Webpack 可以很好地支持各种现代与旧版浏览器,并提供大量工具和插件来帮助处理浏览器兼容性问题。
    • 缺点:为旧版浏览器提供兼容支持通常会增加打包复杂性和配置时间。

总结

特性Vite 优点Vite 缺点Webpack 优点Webpack 缺点
启动速度极速冷启动,适合大型项目仅现代浏览器支持最佳经过多次优化,支持缓存冷启动较慢,特别是大型项目
HMR高效的热更新,毫秒级响应对特别复杂项目 HMR 效果可能减弱HMR 支持成熟HMR 速度较慢
开发模式基于 ESM 的快速开发模式现代浏览器支持最佳功能强大,适应各种需求打包过程较慢
生产环境打包使用 Rollup 打包,打包结果轻量优化需要 Rollup 插件支持,生态不如 Webpack 完善生态成熟,功能丰富构建时间可能较长,配置复杂
依赖处理使用 esbuild 预构建依赖,编译速度快旧依赖库可能需要额外处理依赖处理成熟依赖处理速度相对较慢
插件生态插件开发简单,生态快速成长插件数量和成熟度不如 Webpack插件丰富,几乎支持所有场景插件多样性增加了配置复杂度
兼容性支持现代浏览器的最佳开发体验兼容旧浏览器需要额外配置良好的旧浏览器兼容性为旧浏览器提供支持可能增加打包体积与复杂度

适用场景

  • Vite:适合现代开发项目,特别是使用 Vue、React 等框架的中小型或大型项目,开发体验流畅。
  • Webpack:适合兼容性要求高、复杂度高的大型项目,特别是需要处理复杂的构建需求。

 vite官网:https://cn.vite.dev/guide/why.html

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

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

相关文章

Arduino Uno 同时控制多路舵机

Arduino Uno同时控制4个舵机 舵机可以在0~180度内指定角度的控制。常用于航模、机器人、遥控玩具等物品,然而,很多时候要一次性控制多个舵机,今天以控制4个舵机为例进行说明 接线方式如下图: 舵机的信号线分别接A0,A1,A2,A3。控制舵机从0旋转到180度,再由180度旋转到0度,…

基于NERF技术重建学习笔记

NeRF(Neural Radiance Fields)是一种用于3D场景重建的神经网络模型,能够从2D图像生成逼真的3D渲染效果。它将场景表征为一个连续的5D函数,利用了体积渲染和神经网络的结合,通过学习光线穿过空间时的颜色和密度来重建场…

机器视觉-相机、镜头、光源(总结)

目录 1、机器视觉光源概述 2、光源的作用 3、光谱 4、工业场景常见光源 4.1、白炽灯 4.2、卤素灯 4.3、 荧光灯 4.4、LED灯 4.5、激光灯 5、光源的基本性能 5.1、光通量 5.2、光效率 5.3、发光强度 5.4、光照度 5.5、均匀性 5.6、色温 5.7、显色性 6、基本光学…

openpnp - 解决“底部相机高级校正成功后, 开机归零时,吸嘴自动校验失败的问题“

文章目录 openpnp - 解决"底部相机高级校正成功后, 开机归零时,吸嘴自动校验失败的问题"概述笔记问题现象1问题现象2原因分析现在底部相机和吸嘴的位置偏差记录修正底部相机位置现在再看看NT1在底部相机中的位置开机归零,看看是否能通过所有校…

python csv库

python csv库 水一水又是一篇,乐 读取 import csv # 打开 CSV 文件 with open(example.csv, moder, newline) as file: csv_reader csv.reader(file) # 读取文件头(可选) headers next(csv_reader) print(f"Headers: {heade…

golang将指针传给cgo后还能被回收吗?

问题&#xff1a; 如果把golang分配的变量&#xff0c;其指针通过cgo传给c&#xff0c;并被c存储&#xff0c;那这个变量还能被gc回收吗&#xff1f; 实验代码&#xff1a; test_memory_leak.go package main/* #include <stdlib.h> #include <string.h> #incl…

基于docker-compose编排部署微服务快速开发框架

1. 规划节点 节点规划&#xff0c;见表1。 表1 节点规划 IP主机名节点10.24.2.10masterdocker-compose节点 2. 基础准备 Docker和Docker Compose已安装完成&#xff0c;将提供的软件包Pig.tar.gz上传至master节点/root目录下并解压。 案例实施 1. 基础环境准备 &#x…

渗透测试-百日筑基—SQL注入篇时间注入绕过HTTP数据编码绕过—下

day8-渗透测试sql注入篇&时间注入&绕过&HTTP数据编码绕过 一、时间注入 SQL注入时间注入&#xff08;也称为延时注入&#xff09;是SQL注入攻击的一种特殊形式&#xff0c;它属于盲注&#xff08;Blind SQL Injection&#xff09;的一种。在盲注中&#xff0c;攻击…

模型评估:Accuracy、Precision、Recall、F1、ROC曲线、AUC、PR曲线

Accuracy & Precision & Recall & F1 准确率 Accuracy A c c u r a c y T T T F A L L Accuracy \frac{TT TF}{ALL} AccuracyALLTTTF​ 1.分类器到底分对了多少&#xff1f; 精确率 Precision 2.返回的图片中正确的有多少&#xff1f; 召回率 / 查全率 …

了解光耦合器输入输出关系---腾恩科技

光耦合器&#xff0c;也称为光隔离器&#xff0c;是电子电路中必不可少的元件&#xff0c;主要用于在隔离部分之间传输信号&#xff0c;同时防止电噪声或高压影响敏感元件。其独特的设计使它们能够在没有直接电接触的情况下&#xff0c;弥合不同电压域之间的差距。在本文中&…

解决docker拉取readeck镜像报Error response from daemon: toomanyrequests问题

readeck 是一个内容中心&#xff0c;目前已支持中文翻译 这是本地化部署后的效果&#xff1a; 原命令为&#xff1a; docker run --rm -ti -p 8000:8000 -v readeck-data:/readeck codeberg.org/readeck/readeck:latest Unable to find image codeberg.org/readeck/readeck:la…

LeetCode 热题 100之普通数组

1.最大子数组和 思路分析&#xff1a;这个问题可以通过动态规划来解决&#xff0c;我们可以使用Kadane’s Algorithm&#xff08;卡登算法&#xff09;来找到具有最大和的连续子数组。 Kadane’s Algorithm 的核心思想是利用一个变量存储当前的累加和 currentSum&#xff0c;并…

【高中生讲机器学习】22. 信息论基础:信息熵、交叉熵、相对熵

创建时间&#xff1a;2024-10-16 首发时间&#xff1a;2024-10-24 最后编辑时间&#xff1a;2024-10-24 作者&#xff1a;Geeker_LStar FIRST OF ALL!!! 2024.10.24&#xff01;&#xff01; 1024 快乐&#xff01;&#xff01;&#xff01; 你好呀~这里是 Geeker_LStar 的人工…

IDEA初探:深入理解 Structure 功能

一、Structure - 类视图 Structure 是 IDEA 中的一个视图工具&#xff0c;它提供了对当前文件中结构元素的快速访问。通过 Structure&#xff0c;我们可以方便地查看和导航到代码中的各个部分&#xff0c;从而提高代码编辑和浏览的效率。 1.1 基本概念 Structure 视图以树形结…

Spring Boot:植物健康监测的智能先锋

摘要 随着信息技术在管理上越来越深入而广泛的应用&#xff0c;管理信息系统的实施在技术上已逐步成熟。本文介绍了植物健康系统的开发全过程。通过分析植物健康系统管理的不足&#xff0c;创建了一个计算机管理植物健康系统的方案。文章介绍了植物健康系统的系统分析部分&…

一文带你搞懂RabbitMQ 如何保证消息不丢失

RabbitMQ使用场景&#xff1a; 异步发送&#xff08;验证码、短信、邮件&#xff09;MySQL和Redis&#xff0c;ES之间的数据同步分布式事务削峰填谷 什么情况下消息容易丢失&#xff1a; 消息未到达交换机消息未到达队列队列中消息丢失消费者未接收到消息 解决消息丢失的方法…

python查询并安装项目所依赖的所有包

引言 如果需要进行代码的移植&#xff0c;肯定少不了在另一台pc或者服务器上进行环境的搭建&#xff0c;那么首先是要知道在已有的工程的代码中用到了哪些包&#xff0c;此时&#xff0c;如果是用人工去一个一个的代码文件中去查看调用了哪些包&#xff0c;这个工作甚是繁琐。…

js面试问题笔记(一)

一.热门js面试 1.简述同步和异步的区别? 同步: 浏览器访问服务器请求,用户看到页面刷新 ,重新发请求,等请求完,页面刷新,新内容出现,用户看到新内容,进行下一步操作 异步: 浏览器访问服务器请求,用户正常操作,浏览器后端进行请求,等请求完,页面不刷新,新内容也会出现,用户看到…

【HarmonyOS Next】原生沉浸式界面

背景 在实际项目中&#xff0c;为了软件使用整体色调看起来统一&#xff0c;一般顶部和底部的颜色需要铺满整个手机屏幕。因此&#xff0c;这篇帖子是介绍设置的方法&#xff0c;也是应用沉浸式效果。如下图&#xff1a;底部的绿色延伸到上面的状态栏和下面的导航栏 UI 在鸿蒙…

Grid View 网格视图

GoTo DevExpress Data Grid 数据网格 Grid View 网格视图 GridView 是默认的数据网格视图&#xff0c;它以传统的表格格式显示数据。View 将数据源记录呈现为行&#xff0c;将数据源字段呈现为列。数据值显示在各个单元格中。 以下文档包含有关此表格布局的主要元素的深入信…