Vite的基本介绍以及优劣势(一文读懂vite)?

news2024/11/30 8:47:23

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

  • 一、`Vite`是什么?
  • 二、为什么选Vite?
    • 1、现实的问题
    • 2、缓慢的服务器启动
    • 3、缓慢的更新
  • 三、Vite的`优势`?
  • 四、Vite的`劣势`?
  • 五、`Vite`以及`Webpack`的打包原理?


提示:以下是本篇文章正文内容,下面案例可供参考

一、Vite是什么?

vite是一种新型的前端构建工具,能够显著的提升前端的开发体验,主要由两部分组成:

  • 一个开发服务器:基于原生的ES模块提供了丰富的内建功能,速度快到惊人的模块热更新(HMR)
  • 一套构建指令:使用Rollup打包代码,并且是预配置的,可以输出用于生产环境的高度优化过的静态资源

Vite旨在提供开箱即用的配置,同时他的插件APIJavaScript API带来了高度的可扩展性,并且由完整的类型支持

二、为什么选Vite?

1、现实的问题

1、当开始构建越来越大型的应用的时候,需要处理js的代码量也在增长,基于JavaScript开发的工具就会遇到性能的瓶颈,需要很长的时间才能启动开发服务器,影响开发者的效率和幸福感

2、缓慢的服务器启动

当冷启动开发服务器时,基于打包器的方式启动必须优先抓取并构建你的整个应用,然后才能提供服务。

Vite 通过在一开始将应用中的模块区分为 依赖 源码 两类,改进了开发服务器启动时间。

  • 依赖: 大多数在开发时为不会变动的纯JavaScript。在一些较大的依赖,比如有上百个模块的组件库,处理的代价就很高,依赖也通常会存在多种模块化格式(例如ESM或者CommonJS);Vite就会使用esbuild预构建依赖,esbuild使用Go进行编写,并且以JavaScript编写的打包器构建依赖快10-100倍
  • 源码: 通常包含t一些并非是直接的JavaScript的文件,需要转换(例如JSX,CSS或者是Vue/Svelte组件时),时常会被编辑,同时,并不是所有的源码都需要同时被加载。
  • Vite以原生的ESM方式来提供源码。实际上是让浏览器接管了打包程序的部分工作,Vite只需要在浏览器请求源码的时候进行转换并且按需提供源码,根据情景动态的导入代码

vite

vite2

3、缓慢的更新

基于打包器启动时,重建整个包的效率很低。原因显而易见:因为这样更新速度会随着应用体积增长而直线下降。


三、Vite的优势

  1. 极其快速的服务启动,使用原生的ESM文件,无需进行打包
    2. 轻量快速的热重载,无论应用程序的大小如何,都始终很快的模块热重载(HMR)
  2. 丰富的功能,对于TypeScript、JSX、CSS等支持开箱即用
  3. 优化的构建,可以选择“多页应用”或者“库”模式的预配置Rollup构建
  4. 通用的插件,在开发和构建之间共享Rollup-superset插件接口
  5. 完全类型化的API,灵活的API和完整的TypeScript类型

四、Vite的劣势

  1. 生态不及webpack,加载器插件不够丰富
  2. 打包到生产环境时,Vite使用传统的rollup进行打包
  3. 项目的开发浏览器要支持ES Module,而且不能识别Commjs语法

五、Vite以及Webpack的打包原理?

Webpack的打包原理

webpack
Vite的打包原理
vite

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

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

相关文章

深入理解双亲委派机制

一、双亲委派机制委派流程 双亲委派机制,就是JVM虚拟机加载类的时候,会优先委派上级类加载器进行类加载。 1、如果上级类加载器能找到这个类,那就由上级类加载器加载,并且对下级共享,反之不共享。 2、如果上级类加载…

【#ifndef, #define, 和 #endif】

前言 学习AFNetWoring源码的时候,在AFN的h借接口文件又看到了这几个宏定义,学习记录一下。 作用 #ifndef, #define, 和 #endif是C/CPP的预处理指令,常常用来条件编译和防止头文件重复包含。 简介 #ifndef 它是if not define的简写&…

SpringBoot 使用 Sa-Token 完成注解鉴权功能

注解鉴权 —— 优雅的将鉴权与业务代码分离。本篇我们将介绍在 Sa-Token 中如何通过注解完成权限校验。 Sa-Token 是一个轻量级 java 权限认证框架,主要解决登录认证、权限认证、单点登录、OAuth2、微服务网关鉴权 等一系列权限相关问题。 Gitee 开源地址&#xff1…

生信步骤|EffectorP批量预测病原物效应子

EffectorP软件利用机器学习原理,通过事先收集已知的效应子制备训练集,从而实现病原真菌和卵菌的效应子预测[1]。 EffectorP发展史[2]: 1.0版本最初在16年发表于NEW PHYTOLOGIST,实现了机器学习初步预测效应子。 2.0版本在18年发表…

OPPO官宣:哲库解散,哲库是 OPPO 旗下的芯片厂,类似华为海思的角色,有近 3000 名员工

大家好,我是二哥呀。 这两天,互联网最大的声音之一就是,OPPO 将终止芯片业务,相信大多数小伙伴和二哥一样,第一眼看到这则消息的时候,震惊的同时并惋惜! ZEKU 是 OPPO 旗下的芯片厂&#xff0…

Java面试知识点(全)-JVM面试知识点

Java面试知识点(全) 导航: https://nanxiang.blog.csdn.net/article/details/130640392 注:随时更新 JVM内存结构 内存结构 Java虚拟机在运行程序时会把其自动管理的内存划分为以上几个区域,每个区域都有的用途以及创建销毁的时机&#xf…

【JavaScript】手写Promise

🐱 个人主页:不叫猫先生 🙋‍♂️ 作者简介:2022年度博客之星前端领域TOP 2,前端领域优质作者、阿里云专家博主,专注于前端各领域技术,共同学习共同进步,一起加油呀! &am…

五. AMS实践,Hook启动未注册的Activity

Activity任务栈解析 正常情况下我们的app中的所有Activity都是运行在同一个任务栈(ActivityStack)里面的,也就是我们app的build.gradle文件中的applicationId那个任务栈. 如何实现Activity运行在不同的任务栈呢? 需要在Intent启动这个Activity的时候,给这个intent赋值,设置代…

【KVM虚拟化】· 存储池、存储卷

目录 🍁虚拟磁盘文件 🍂基于文件系统的KVM存储 🍂基于设备的KVM存储 🍁使用KVM存储池 🍂存储池概念 🍁virsh中存储池命令 🍁virsh中存储卷命令 🍁命令实例 🍂创建存储池 …

一个开源的即时通讯应用 Tailchat

今天给大家介绍一款即时通讯应用,这个开源项目是:Tailchat,它是一个基于 React Typescript 的现代开源 noIM 应用程序。 简单介绍 相信大家都或多或少了解过 Discord / Slack 这样大火的即时通讯应用。两者分别在各自的领域有很大的成就。…

http强缓存和协商缓存的介绍和应用案例,简介明了

http强缓存和协商缓存的介绍和应用案例,简介明了 http缓存方式简介缓存机制案例1. Expires老版本的方式:2. cache-control新版本的方式:3.Etag和If-None-Match http缓存方式简介 强缓存:强缓存使用Expires(老版本&…

el-table实现可编辑表格的思路;el-table删除不正确:表格中的el-select下拉数据项有值,但输入框中value值不显示

目录 一、问题 二、原因及解决方法 三、总结 tips:如嫌繁琐,直接看总结即可! 一、问题 el-table实现可编辑表格的思路: 1.要写一个可编辑的表格:表格中的一列是下拉框。实现方法很简单:在el-table-column(elemen提…

PMP课堂模拟题目及解析(第9期)

81. 一位经验丰富的项目经理在到达一个重大开发里程碑之前识别到一个问题,项目经理采取相应的行动,并能够按时解决问题。两周后,发起人通知项目经理,客户发出了处罚费。若要避免这个问题,项目经理应该事先做什么&…

FGX Native 1.4.1.1 For Delphi Crack

FGX Native 1.4.1.1 For Delphi Crack FGX Native Network Frame是制造跨平台和现代移动设备的强大工具。FG开发团队的主要目标是简化移动应用程序的开发,使大多数人都能以各种技能开发应用程序。此外,这种形式的网络最重要的功能可以在100%的用户界面中…

CorelDRAW2020工作室版下载及新增功能介绍

CorelDRAW Graphics Suite 2020将基于人工智能的图形设计提升到一个全新水平。CorelDRAW 中增强了“查找和替换”\“对齐和分布”、阴影效果等功能。您喜欢的 Corel PHOTO-PAINT 功能 — 从遮罩、效果和透镜到“替换颜色”— 均已优化! 针对操作系统的功能优化 Core…

微信之小程序授权登录

首先我要怒骂微信的后台开发 真的还是乱七八糟。 首先我们登录微信开发平台 选择要开发的类型 然后小程序登录:选择 微信小程序实现微信登录详解(JAVA后台)官方文档:https://developers.weixin.qq.com/miniprogram/dev/framework…

玩转ChatGPT:魔改文章成果格式

一、写在前面 首先,我让小Chat替我吐槽一下: 科研人员天天都在填各种表格,简直成了我们的“表格王子”和“表格公主”。从申请项目、提交论文到汇报成果,表格无处不在。我们填表格的时候总是期待着它能让我们的工作更高效、更顺…

Redis 内存消耗及回收

Redis 是一个开源、高性能的 Key-Value 数据库,被广泛应用在服务器各种场景中。Redis 是一种内存数据库,将数据保存在内存中,读写效率要比传统的将数据保存在磁盘上的数据库要快很多。所以,监控 Redis 的内存消耗并了解 Redis 内存…

tinyWebServer 学习笔记——四、日志系统

文章目录 一、基础知识1. 概念2. API 二、代码解析1. 单例模式2. 阻塞队列3. 日志类定义4. 生成日志文件并判断写入方式5. 日志分级与分文件 参考文献 一、基础知识 1. 概念 流程图 [2] 日志:由服务器自动创建,用于记录运行状态和错误信息;同…

C++系列六:运算符

C运算符 1. 算术运算符2. 关系运算符3. 逻辑运算符4. 按位运算符5. 取地址运算符6. 取内容运算符7. 成员选择符8. 作用域运算符9. 总结 1. 算术运算符 算术运算符用于执行基本数学运算,例如加减乘除和取模等操作。下表列出了C中支持的算术运算符: 运算…